import React from 'react'; import { connect } from 'react-redux'; import ImmutablePureComponent from 'react-immutable-pure-component'; import WhoToFollowPanel from 'soapbox/features/ui/components/who_to_follow_panel'; import TrendsPanel from 'soapbox/features/ui/components/trends_panel'; import PromoPanel from 'soapbox/features/ui/components/promo_panel'; import FeaturesPanel from 'soapbox/features/ui/components/features_panel'; import LinkFooter from 'soapbox/features/ui/components/link_footer'; import { getFeatures } from 'soapbox/utils/features'; import InstanceInfoPanel from 'soapbox/features/ui/components/instance_info_panel'; import InstanceModerationPanel from 'soapbox/features/ui/components/instance_moderation_panel'; import { federationRestrictionsDisclosed } from 'soapbox/utils/state'; import { isAdmin } from 'soapbox/utils/accounts'; const mapStateToProps = state => { const me = state.get('me'); const account = state.getIn(['accounts', me]); const features = getFeatures(state.get('instance')); return { me, showTrendsPanel: features.trends, showWhoToFollowPanel: features.suggestions, disclosed: federationRestrictionsDisclosed(state), isAdmin: isAdmin(account), }; }; export default @connect(mapStateToProps) class RemoteInstancePage extends ImmutablePureComponent { render() { const { me, children, showTrendsPanel, showWhoToFollowPanel, params: { instance: host }, disclosed, isAdmin } = this.props; return (
{(disclosed || isAdmin) && }
{children}
{showTrendsPanel && } {showWhoToFollowPanel && } {me && }
); } }