Merge pull request #489 from ThibG/glitch-soc/features/port-public-ui-changes
Port public UI changes from upstreammaster
commit
5d823ee00a
@ -1,18 +0,0 @@ |
||||
import React from 'react'; |
||||
import PropTypes from 'prop-types'; |
||||
import Card from 'flavours/glitch/features/status/components/card'; |
||||
import { fromJS } from 'immutable'; |
||||
|
||||
export default class CardContainer extends React.PureComponent { |
||||
|
||||
static propTypes = { |
||||
locale: PropTypes.string, |
||||
card: PropTypes.array.isRequired, |
||||
}; |
||||
|
||||
render () { |
||||
const { card, ...props } = this.props; |
||||
return <Card card={fromJS(card)} {...props} />; |
||||
} |
||||
|
||||
} |
@ -0,0 +1,90 @@ |
||||
import React, { PureComponent, Fragment } from 'react'; |
||||
import ReactDOM from 'react-dom'; |
||||
import PropTypes from 'prop-types'; |
||||
import { IntlProvider, addLocaleData } from 'react-intl'; |
||||
import { getLocale } from 'mastodon/locales'; |
||||
import MediaGallery from 'flavours/glitch/components/media_gallery'; |
||||
import Video from 'flavours/glitch/features/video'; |
||||
import Card from 'flavours/glitch/features/status/components/card'; |
||||
import ModalRoot from 'flavours/glitch/components/modal_root'; |
||||
import MediaModal from 'flavours/glitch/features/ui/components/media_modal'; |
||||
import { List as ImmutableList, fromJS } from 'immutable'; |
||||
|
||||
const { localeData, messages } = getLocale(); |
||||
addLocaleData(localeData); |
||||
|
||||
const MEDIA_COMPONENTS = { MediaGallery, Video, Card }; |
||||
|
||||
export default class MediaContainer extends PureComponent { |
||||
|
||||
static propTypes = { |
||||
locale: PropTypes.string.isRequired, |
||||
components: PropTypes.object.isRequired, |
||||
}; |
||||
|
||||
state = { |
||||
media: null, |
||||
index: null, |
||||
time: null, |
||||
}; |
||||
|
||||
handleOpenMedia = (media, index) => { |
||||
document.body.classList.add('media-standalone__body'); |
||||
this.setState({ media, index }); |
||||
} |
||||
|
||||
handleOpenVideo = (video, time) => { |
||||
const media = ImmutableList([video]); |
||||
|
||||
document.body.classList.add('media-standalone__body'); |
||||
this.setState({ media, time }); |
||||
} |
||||
|
||||
handleCloseMedia = () => { |
||||
document.body.classList.remove('media-standalone__body'); |
||||
this.setState({ media: null, index: null, time: null }); |
||||
} |
||||
|
||||
render () { |
||||
const { locale, components } = this.props; |
||||
|
||||
return ( |
||||
<IntlProvider locale={locale} messages={messages}> |
||||
<Fragment> |
||||
{[].map.call(components, (component, i) => { |
||||
const componentName = component.getAttribute('data-component'); |
||||
const Component = MEDIA_COMPONENTS[componentName]; |
||||
const { media, card, ...props } = JSON.parse(component.getAttribute('data-props')); |
||||
|
||||
Object.assign(props, { |
||||
...(media ? { media: fromJS(media) } : {}), |
||||
...(card ? { card: fromJS(card) } : {}), |
||||
|
||||
...(componentName === 'Video' ? { |
||||
onOpenVideo: this.handleOpenVideo, |
||||
} : { |
||||
onOpenMedia: this.handleOpenMedia, |
||||
}), |
||||
}); |
||||
|
||||
return ReactDOM.createPortal( |
||||
<Component {...props} key={`media-${i}`} />, |
||||
component, |
||||
); |
||||
})} |
||||
<ModalRoot onClose={this.handleCloseMedia}> |
||||
{this.state.media && ( |
||||
<MediaModal |
||||
media={this.state.media} |
||||
index={this.state.index || 0} |
||||
time={this.state.time} |
||||
onClose={this.handleCloseMedia} |
||||
/> |
||||
)} |
||||
</ModalRoot> |
||||
</Fragment> |
||||
</IntlProvider> |
||||
); |
||||
} |
||||
|
||||
} |
@ -1,68 +0,0 @@ |
||||
import React from 'react'; |
||||
import ReactDOM from 'react-dom'; |
||||
import PropTypes from 'prop-types'; |
||||
import { IntlProvider, addLocaleData } from 'react-intl'; |
||||
import { getLocale } from 'mastodon/locales'; |
||||
import MediaGallery from 'flavours/glitch/components/media_gallery'; |
||||
import ModalRoot from 'flavours/glitch/components/modal_root'; |
||||
import MediaModal from 'flavours/glitch/features/ui/components/media_modal'; |
||||
import { fromJS } from 'immutable'; |
||||
|
||||
const { localeData, messages } = getLocale(); |
||||
addLocaleData(localeData); |
||||
|
||||
export default class MediaGalleriesContainer extends React.PureComponent { |
||||
|
||||
static propTypes = { |
||||
locale: PropTypes.string.isRequired, |
||||
galleries: PropTypes.object.isRequired, |
||||
}; |
||||
|
||||
state = { |
||||
media: null, |
||||
index: null, |
||||
}; |
||||
|
||||
handleOpenMedia = (media, index) => { |
||||
document.body.classList.add('media-gallery-standalone__body'); |
||||
this.setState({ media, index }); |
||||
} |
||||
|
||||
handleCloseMedia = () => { |
||||
document.body.classList.remove('media-gallery-standalone__body'); |
||||
this.setState({ media: null, index: null }); |
||||
} |
||||
|
||||
render () { |
||||
const { locale, galleries } = this.props; |
||||
|
||||
return ( |
||||
<IntlProvider locale={locale} messages={messages}> |
||||
<React.Fragment> |
||||
{[].map.call(galleries, gallery => { |
||||
const { media, ...props } = JSON.parse(gallery.getAttribute('data-props')); |
||||
|
||||
return ReactDOM.createPortal( |
||||
<MediaGallery |
||||
{...props} |
||||
media={fromJS(media)} |
||||
onOpenMedia={this.handleOpenMedia} |
||||
/>, |
||||
gallery |
||||
); |
||||
})} |
||||
<ModalRoot onClose={this.handleCloseMedia}> |
||||
{this.state.media === null || this.state.index === null ? null : ( |
||||
<MediaModal |
||||
media={this.state.media} |
||||
index={this.state.index} |
||||
onClose={this.handleCloseMedia} |
||||
/> |
||||
)} |
||||
</ModalRoot> |
||||
</React.Fragment> |
||||
</IntlProvider> |
||||
); |
||||
} |
||||
|
||||
} |
@ -1,26 +0,0 @@ |
||||
import React from 'react'; |
||||
import PropTypes from 'prop-types'; |
||||
import { IntlProvider, addLocaleData } from 'react-intl'; |
||||
import { getLocale } from 'mastodon/locales'; |
||||
import Video from 'flavours/glitch/features/video'; |
||||
|
||||
const { localeData, messages } = getLocale(); |
||||
addLocaleData(localeData); |
||||
|
||||
export default class VideoContainer extends React.PureComponent { |
||||
|
||||
static propTypes = { |
||||
locale: PropTypes.string.isRequired, |
||||
}; |
||||
|
||||
render () { |
||||
const { locale, ...props } = this.props; |
||||
|
||||
return ( |
||||
<IntlProvider locale={locale} messages={messages}> |
||||
<Video {...props} /> |
||||
</IntlProvider> |
||||
); |
||||
} |
||||
|
||||
} |
Loading…
Reference in new issue