Merge branch 'conditional-subscriptions' into 'develop'

Conditionally display subscription button for Pleroma >= 1.0.0

See merge request soapbox-pub/soapbox-fe!753
This commit is contained in:
Alex Gleason 2021-09-13 17:43:34 +00:00
commit 3f01004afe
2 changed files with 12 additions and 8 deletions

View file

@ -17,7 +17,6 @@ import {
isRemote, isRemote,
getDomain, getDomain,
} from 'soapbox/utils/accounts'; } from 'soapbox/utils/accounts';
import { parseVersion } from 'soapbox/utils/features';
import classNames from 'classnames'; import classNames from 'classnames';
import Avatar from 'soapbox/components/avatar'; import Avatar from 'soapbox/components/avatar';
import { shortNumberFormat } from 'soapbox/utils/numbers'; import { shortNumberFormat } from 'soapbox/utils/numbers';
@ -30,6 +29,7 @@ import ActionButton from 'soapbox/features/ui/components/action_button';
import SubscriptionButton from 'soapbox/features/ui/components/subscription_button'; import SubscriptionButton from 'soapbox/features/ui/components/subscription_button';
import { openModal } from 'soapbox/actions/modal'; import { openModal } from 'soapbox/actions/modal';
import { List as ImmutableList, Map as ImmutableMap } from 'immutable'; import { List as ImmutableList, Map as ImmutableMap } from 'immutable';
import { getFeatures } from 'soapbox/utils/features';
const messages = defineMessages({ const messages = defineMessages({
edit_profile: { id: 'account.edit_profile', defaultMessage: 'Edit profile' }, edit_profile: { id: 'account.edit_profile', defaultMessage: 'Edit profile' },
@ -72,11 +72,13 @@ const messages = defineMessages({
const mapStateToProps = state => { const mapStateToProps = state => {
const me = state.get('me'); const me = state.get('me');
const account = state.getIn(['accounts', me]); const account = state.getIn(['accounts', me]);
const instance = state.get('instance');
const features = getFeatures(instance);
return { return {
me, me,
meAccount: account, meAccount: account,
version: parseVersion(state.getIn(['instance', 'version'])), features,
}; };
}; };
@ -90,7 +92,7 @@ class Header extends ImmutablePureComponent {
identity_props: ImmutablePropTypes.list, identity_props: ImmutablePropTypes.list,
intl: PropTypes.object.isRequired, intl: PropTypes.object.isRequired,
username: PropTypes.string, username: PropTypes.string,
version: PropTypes.object, features: PropTypes.object,
}; };
state = { state = {
@ -156,7 +158,7 @@ class Header extends ImmutablePureComponent {
} }
makeMenu() { makeMenu() {
const { account, intl, me, meAccount, version } = this.props; const { account, intl, me, meAccount, features } = this.props;
const menu = []; const menu = [];
@ -196,7 +198,7 @@ class Header extends ImmutablePureComponent {
menu.push({ text: intl.formatMessage(messages.add_or_remove_from_list), action: this.props.onAddToList }); menu.push({ text: intl.formatMessage(messages.add_or_remove_from_list), action: this.props.onAddToList });
// menu.push({ text: intl.formatMessage(account.getIn(['relationship', 'endorsed']) ? messages.unendorse : messages.endorse), action: this.props.onEndorseToggle }); // menu.push({ text: intl.formatMessage(account.getIn(['relationship', 'endorsed']) ? messages.unendorse : messages.endorse), action: this.props.onEndorseToggle });
menu.push(null); menu.push(null);
} else if (version.software === 'Pleroma') { } else if (features.unrestrictedLists) {
menu.push({ text: intl.formatMessage(messages.add_or_remove_from_list), action: this.props.onAddToList }); menu.push({ text: intl.formatMessage(messages.add_or_remove_from_list), action: this.props.onAddToList });
} }
@ -285,7 +287,7 @@ class Header extends ImmutablePureComponent {
} }
render() { render() {
const { account, intl, username, me } = this.props; const { account, intl, username, me, features } = this.props;
const { isSmallScreen } = this.state; const { isSmallScreen } = this.state;
if (!account) { if (!account) {
@ -323,9 +325,9 @@ class Header extends ImmutablePureComponent {
{info} {info}
</div> </div>
<div className='account__header__subscribe'> {features.accountSubscriptions && <div className='account__header__subscribe'>
<SubscriptionButton account={account} /> <SubscriptionButton account={account} />
</div> </div>}
{header && <a className='account__header__header' href={account.get('header')} onClick={this.handleHeaderClick} target='_blank'> {header && <a className='account__header__header' href={account.get('header')} onClick={this.handleHeaderClick} target='_blank'>
<StillImage src={account.get('header')} alt='' className='parallax' /> <StillImage src={account.get('header')} alt='' className='parallax' />

View file

@ -26,6 +26,8 @@ export const getFeatures = createSelector([
accountAliasesAPI: v.software === 'Pleroma', accountAliasesAPI: v.software === 'Pleroma',
resetPasswordAPI: v.software === 'Pleroma', resetPasswordAPI: v.software === 'Pleroma',
exposableReactions: features.includes('exposable_reactions'), exposableReactions: features.includes('exposable_reactions'),
accountSubscriptions: v.software === 'Pleroma' && gte(v.version, '1.0.0'),
unrestrictedLists: v.software === 'Pleroma',
}; };
}); });