2020-05-07 01:55:24 -04:00
|
|
|
import { Fragment } from 'react'
|
2020-02-28 10:20:47 -05:00
|
|
|
import { closeModal } from '../../actions/modal'
|
|
|
|
import { cancelReplyCompose } from '../../actions/compose'
|
2020-02-24 16:56:07 -05:00
|
|
|
import Bundle from '../../features/ui/util/bundle'
|
2020-05-01 01:50:27 -04:00
|
|
|
import ModalBase from './modal_base'
|
|
|
|
import BundleModalError from '../bundle_modal_error'
|
2020-02-28 10:20:47 -05:00
|
|
|
import {
|
2020-04-28 01:33:58 -04:00
|
|
|
MODAL_ACTIONS,
|
|
|
|
MODAL_BLOCK_ACCOUNT,
|
|
|
|
MODAL_BOOST,
|
|
|
|
MODAL_COMMUNITY_TIMELINE_SETTINGS,
|
|
|
|
MODAL_COMPOSE,
|
|
|
|
MODAL_CONFIRM,
|
|
|
|
MODAL_DISPLAY_OPTIONS,
|
|
|
|
MODAL_EDIT_PROFILE,
|
|
|
|
MODAL_EMBED,
|
|
|
|
MODAL_GIF_PICKER,
|
|
|
|
MODAL_GROUP_CREATE,
|
|
|
|
MODAL_GROUP_DELETE,
|
2020-05-07 00:03:34 -04:00
|
|
|
MODAL_GROUP_MEMBERS,
|
2020-05-07 01:55:24 -04:00
|
|
|
MODAL_GROUP_REMOVED_ACCOUNTS,
|
2020-04-28 01:33:58 -04:00
|
|
|
MODAL_HASHTAG_TIMELINE_SETTINGS,
|
|
|
|
MODAL_HOME_TIMELINE_SETTINGS,
|
|
|
|
MODAL_HOTKEYS,
|
|
|
|
MODAL_LIST_CREATE,
|
|
|
|
MODAL_LIST_DELETE,
|
|
|
|
MODAL_LIST_EDITOR,
|
|
|
|
MODAL_LIST_TIMELINE_SETTINGS,
|
|
|
|
MODAL_MEDIA,
|
|
|
|
MODAL_MUTE,
|
|
|
|
MODAL_PRO_UPGRADE,
|
|
|
|
MODAL_REPORT,
|
2020-05-03 01:22:49 -04:00
|
|
|
MODAL_STATUS_LIKES,
|
|
|
|
MODAL_STATUS_REPOSTS,
|
2020-04-28 01:33:58 -04:00
|
|
|
MODAL_STATUS_REVISIONS,
|
|
|
|
MODAL_UNAUTHORIZED,
|
|
|
|
MODAL_UNFOLLOW,
|
|
|
|
MODAL_VIDEO,
|
|
|
|
} from '../../constants'
|
|
|
|
import {
|
|
|
|
ActionsModal,
|
|
|
|
BlockAccountModal,
|
|
|
|
BoostModal,
|
|
|
|
CommunityTimelineSettingsModal,
|
|
|
|
ComposeModal,
|
|
|
|
ConfirmationModal,
|
|
|
|
DisplayOptionsModal,
|
|
|
|
EditProfileModal,
|
|
|
|
EmbedModal,
|
|
|
|
GifPickerModal,
|
|
|
|
GroupCreateModal,
|
|
|
|
GroupDeleteModal,
|
2020-05-07 00:03:34 -04:00
|
|
|
GroupMembersModal,
|
2020-05-07 01:55:24 -04:00
|
|
|
GroupRemovedAccountsModal,
|
2020-04-28 01:33:58 -04:00
|
|
|
HashtagTimelineSettingsModal,
|
|
|
|
HomeTimelineSettingsModal,
|
|
|
|
HotkeysModal,
|
|
|
|
ListCreateModal,
|
|
|
|
ListDeleteModal,
|
|
|
|
ListEditorModal,
|
|
|
|
ListTimelineSettingsModal,
|
|
|
|
MediaModal,
|
2020-02-28 10:20:47 -05:00
|
|
|
MuteModal,
|
2020-04-28 01:33:58 -04:00
|
|
|
ProUpgradeModal,
|
2020-02-28 10:20:47 -05:00
|
|
|
ReportModal,
|
2020-05-03 01:22:49 -04:00
|
|
|
StatusLikesModal,
|
|
|
|
StatusRepostsModal,
|
2020-03-27 18:57:03 -04:00
|
|
|
StatusRevisionsModal,
|
2020-04-28 01:33:58 -04:00
|
|
|
UnauthorizedModal,
|
|
|
|
UnfollowModal,
|
|
|
|
VideoModal,
|
2020-03-24 23:08:43 -04:00
|
|
|
} from '../../features/ui/util/async_components'
|
2020-03-24 00:39:12 -04:00
|
|
|
|
2020-04-28 01:33:58 -04:00
|
|
|
const MODAL_COMPONENTS = {}
|
|
|
|
MODAL_COMPONENTS[MODAL_ACTIONS] = ActionsModal
|
|
|
|
MODAL_COMPONENTS[MODAL_BLOCK_ACCOUNT] = BlockAccountModal
|
|
|
|
MODAL_COMPONENTS[MODAL_BOOST] = BoostModal
|
|
|
|
MODAL_COMPONENTS[MODAL_COMMUNITY_TIMELINE_SETTINGS] = CommunityTimelineSettingsModal
|
|
|
|
MODAL_COMPONENTS[MODAL_COMPOSE] = ComposeModal
|
|
|
|
MODAL_COMPONENTS[MODAL_CONFIRM] = ConfirmationModal
|
|
|
|
MODAL_COMPONENTS[MODAL_DISPLAY_OPTIONS] = DisplayOptionsModal
|
|
|
|
MODAL_COMPONENTS[MODAL_EDIT_PROFILE] = EditProfileModal
|
|
|
|
MODAL_COMPONENTS[MODAL_EMBED] = EmbedModal
|
|
|
|
MODAL_COMPONENTS[MODAL_GIF_PICKER] = GifPickerModal
|
|
|
|
MODAL_COMPONENTS[MODAL_GROUP_CREATE] = GroupCreateModal
|
|
|
|
MODAL_COMPONENTS[MODAL_GROUP_DELETE] = GroupDeleteModal
|
2020-05-07 00:03:34 -04:00
|
|
|
MODAL_COMPONENTS[MODAL_GROUP_MEMBERS] = GroupMembersModal
|
2020-05-07 01:55:24 -04:00
|
|
|
MODAL_COMPONENTS[MODAL_GROUP_REMOVED_ACCOUNTS] = GroupRemovedAccountsModal
|
2020-04-28 01:33:58 -04:00
|
|
|
MODAL_COMPONENTS[MODAL_HASHTAG_TIMELINE_SETTINGS] = HashtagTimelineSettingsModal
|
|
|
|
MODAL_COMPONENTS[MODAL_HOME_TIMELINE_SETTINGS] = HomeTimelineSettingsModal
|
|
|
|
MODAL_COMPONENTS[MODAL_HOTKEYS] = HotkeysModal
|
|
|
|
MODAL_COMPONENTS[MODAL_LIST_CREATE] = ListCreateModal
|
|
|
|
MODAL_COMPONENTS[MODAL_LIST_DELETE] = ListDeleteModal
|
|
|
|
MODAL_COMPONENTS[MODAL_LIST_EDITOR] = ListEditorModal
|
|
|
|
MODAL_COMPONENTS[MODAL_LIST_TIMELINE_SETTINGS] = ListTimelineSettingsModal
|
|
|
|
MODAL_COMPONENTS[MODAL_MEDIA] = MediaModal
|
|
|
|
MODAL_COMPONENTS[MODAL_MUTE] = MuteModal
|
|
|
|
MODAL_COMPONENTS[MODAL_PRO_UPGRADE] = ProUpgradeModal
|
|
|
|
MODAL_COMPONENTS[MODAL_REPORT] = ReportModal
|
2020-05-03 01:22:49 -04:00
|
|
|
MODAL_COMPONENTS[MODAL_STATUS_LIKES] = StatusLikesModal
|
|
|
|
MODAL_COMPONENTS[MODAL_STATUS_REPOSTS] = StatusRepostsModal
|
2020-04-28 01:33:58 -04:00
|
|
|
MODAL_COMPONENTS[MODAL_STATUS_REVISIONS] = StatusRevisionsModal
|
|
|
|
MODAL_COMPONENTS[MODAL_UNAUTHORIZED] = UnauthorizedModal
|
|
|
|
MODAL_COMPONENTS[MODAL_UNFOLLOW] = UnfollowModal
|
|
|
|
MODAL_COMPONENTS[MODAL_VIDEO] = VideoModal
|
2019-07-02 03:10:25 -04:00
|
|
|
|
2020-05-14 16:45:39 -04:00
|
|
|
const CENTERED_XS_MODALS = [
|
|
|
|
MODAL_BLOCK_ACCOUNT,
|
|
|
|
MODAL_CONFIRM,
|
|
|
|
MODAL_GROUP_DELETE,
|
|
|
|
MODAL_LIST_DELETE,
|
|
|
|
MODAL_MUTE,
|
|
|
|
MODAL_UNAUTHORIZED,
|
|
|
|
MODAL_UNFOLLOW,
|
|
|
|
]
|
|
|
|
|
2020-04-11 18:29:19 -04:00
|
|
|
const mapStateToProps = (state) => ({
|
2020-04-07 21:06:59 -04:00
|
|
|
type: state.getIn(['modal', 'modalType']),
|
|
|
|
props: state.getIn(['modal', 'modalProps'], {}),
|
2020-02-28 10:20:47 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
const mapDispatchToProps = (dispatch) => ({
|
2020-03-24 00:39:12 -04:00
|
|
|
onClose(optionalType) {
|
2020-02-28 10:20:47 -05:00
|
|
|
if (optionalType === 'COMPOSE') {
|
2020-03-24 00:39:12 -04:00
|
|
|
dispatch(cancelReplyCompose())
|
2020-02-28 10:20:47 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(closeModal())
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
export default
|
|
|
|
@connect(mapStateToProps, mapDispatchToProps)
|
|
|
|
class ModalRoot extends PureComponent {
|
2019-07-02 03:10:25 -04:00
|
|
|
|
|
|
|
static propTypes = {
|
|
|
|
type: PropTypes.string,
|
|
|
|
props: PropTypes.object,
|
|
|
|
onClose: PropTypes.func.isRequired,
|
2020-02-24 16:56:07 -05:00
|
|
|
}
|
2019-07-02 03:10:25 -04:00
|
|
|
|
2020-03-24 00:39:12 -04:00
|
|
|
getSnapshotBeforeUpdate() {
|
2020-02-24 16:56:07 -05:00
|
|
|
return { visible: !!this.props.type }
|
2019-07-02 03:10:25 -04:00
|
|
|
}
|
|
|
|
|
2020-03-24 00:39:12 -04:00
|
|
|
componentDidUpdate(prevProps, prevState, { visible }) {
|
2019-07-02 03:10:25 -04:00
|
|
|
if (visible) {
|
2020-04-22 01:00:11 -04:00
|
|
|
document.body.classList.add(_s.overflowYHidden)
|
2019-07-02 03:10:25 -04:00
|
|
|
} else {
|
2020-04-22 01:00:11 -04:00
|
|
|
document.body.classList.remove(_s.overflowYHidden)
|
2019-07-02 03:10:25 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-01 01:50:27 -04:00
|
|
|
renderLoading = () => {
|
2020-05-02 02:25:55 -04:00
|
|
|
return null
|
2019-07-02 03:10:25 -04:00
|
|
|
}
|
|
|
|
|
2020-05-01 01:50:27 -04:00
|
|
|
renderError = () => {
|
|
|
|
return <BundleModalError {...this.props} onClose={this.onClickClose} />
|
2019-07-02 03:10:25 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
onClickClose = () => {
|
2020-04-06 21:53:23 -04:00
|
|
|
this.props.onClose(this.props.type)
|
2019-07-02 03:10:25 -04:00
|
|
|
}
|
|
|
|
|
2020-03-24 00:39:12 -04:00
|
|
|
render() {
|
2020-02-24 16:56:07 -05:00
|
|
|
const { type, props } = this.props
|
|
|
|
const visible = !!type
|
2019-07-02 03:10:25 -04:00
|
|
|
|
|
|
|
return (
|
2020-05-14 16:45:39 -04:00
|
|
|
<ModalBase
|
|
|
|
onClose={this.onClickClose}
|
|
|
|
isCenteredXS={CENTERED_XS_MODALS.indexOf(type) > -1}
|
|
|
|
type={type}
|
|
|
|
>
|
2020-02-24 16:56:07 -05:00
|
|
|
{
|
|
|
|
visible &&
|
|
|
|
<Bundle
|
|
|
|
fetchComponent={MODAL_COMPONENTS[type]}
|
2020-05-01 01:50:27 -04:00
|
|
|
loading={this.renderLoading}
|
2020-02-24 16:56:07 -05:00
|
|
|
error={this.renderError}
|
|
|
|
renderDelay={200}
|
|
|
|
>
|
|
|
|
{
|
2020-05-01 01:50:27 -04:00
|
|
|
(Component) => <Component {...props} onClose={this.onClickClose} />
|
2020-02-24 16:56:07 -05:00
|
|
|
}
|
2019-08-07 01:02:36 -04:00
|
|
|
</Bundle>
|
2020-02-24 16:56:07 -05:00
|
|
|
}
|
|
|
|
</ModalBase>
|
|
|
|
)
|
2019-07-02 03:10:25 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|