bigbuffet-rw/app/soapbox/features/ui/components/features_panel.js

109 lines
4.2 KiB
JavaScript

import { OrderedSet as ImmutableOrderedSet } from 'immutable';
import PropTypes from 'prop-types';
import React from 'react';
import { injectIntl, defineMessages } from 'react-intl';
import { connect } from 'react-redux';
import { NavLink } from 'react-router-dom';
import Icon from 'soapbox/components/icon';
import IconWithCounter from 'soapbox/components/icon_with_counter';
import { getBaseURL } from 'soapbox/utils/accounts';
import { getFeatures } from 'soapbox/utils/features';
const messages = defineMessages({
edit_profile: { id: 'account.edit_profile', defaultMessage: 'Edit Profile' },
preferences: { id: 'navigation_bar.preferences', defaultMessage: 'Preferences' },
security: { id: 'navigation_bar.security', defaultMessage: 'Security' },
lists: { id: 'column.lists', defaultMessage: 'Lists' },
bookmarks: { id: 'column.bookmarks', defaultMessage: 'Bookmarks' },
follow_requests: { id: 'navigation_bar.follow_requests', defaultMessage: 'Follow requests' },
});
const mapStateToProps = state => {
const me = state.get('me');
const account = state.getIn(['accounts', me]);
const instance = state.get('instance');
const features = getFeatures(instance);
return {
isLocked: state.getIn(['accounts', me, 'locked']),
followRequestsCount: state.getIn(['user_lists', 'follow_requests', 'items'], ImmutableOrderedSet()).count(),
baseURL: getBaseURL(account),
features,
};
};
export default @connect(mapStateToProps)
@injectIntl
class FeaturesPanel extends React.PureComponent {
static propTypes = {
intl: PropTypes.object.isRequired,
isLocked: PropTypes.bool,
followRequestsCount: PropTypes.number,
baseURL: PropTypes.string,
features: PropTypes.object.isRequired,
};
render() {
const { intl, isLocked, followRequestsCount, baseURL, features } = this.props;
return (
<div className='wtf-panel promo-panel'>
<div className='promo-panel__container'>
<NavLink className='promo-panel-item' to='/settings/profile'>
<Icon src={require('@tabler/icons/icons/user.svg')} className='promo-panel-item__icon' />
{intl.formatMessage(messages.edit_profile)}
</NavLink>
{(isLocked || followRequestsCount > 0) && <NavLink className='promo-panel-item' to='/follow_requests'>
<IconWithCounter src={require('@tabler/icons/icons/user-plus.svg')} count={followRequestsCount} className='promo-panel-item__icon' />
{intl.formatMessage(messages.follow_requests)}
</NavLink>}
{features.bookmarks && (
<NavLink className='promo-panel-item' to='/bookmarks'>
<Icon src={require('@tabler/icons/icons/bookmark.svg')} className='promo-panel-item__icon' />
{intl.formatMessage(messages.bookmarks)}
</NavLink>
)}
{features.lists && (
<NavLink className='promo-panel-item' to='/lists'>
<Icon src={require('@tabler/icons/icons/list.svg')} className='promo-panel-item__icon' />
{intl.formatMessage(messages.lists)}
</NavLink>
)}
{features.securityAPI ? (
<NavLink className='promo-panel-item' to='/auth/edit'>
<Icon src={require('@tabler/icons/icons/lock.svg')} className='promo-panel-item__icon' />
{intl.formatMessage(messages.security)}
</NavLink>
) : (
<a className='promo-panel-item' href={`${baseURL}/auth/edit`}>
<Icon src={require('@tabler/icons/icons/lock.svg')} className='promo-panel-item__icon' />
{intl.formatMessage(messages.security)}
</a>
)}
{features.settingsStore ? (
<NavLink className='promo-panel-item' to='/settings/preferences'>
<Icon src={require('@tabler/icons/icons/settings.svg')} className='promo-panel-item__icon' />
{intl.formatMessage(messages.preferences)}
</NavLink>
) : (
<a className='promo-panel-item' href={`${baseURL}/settings/preferences`}>
<Icon src={require('@tabler/icons/icons/settings.svg')} className='promo-panel-item__icon' />
{intl.formatMessage(messages.preferences)}
</a>
)}
</div>
</div>
);
}
}