Merge branch 'next-conditional-profile' into 'next'

Next: EditProfile: conditional features

See merge request soapbox-pub/soapbox-fe!1232
This commit is contained in:
Alex Gleason 2022-04-17 02:31:28 +00:00
commit 9f962ccec3
2 changed files with 38 additions and 29 deletions

View file

@ -56,12 +56,13 @@ const makeMapStateToProps = () => {
const me = state.get('me'); const me = state.get('me');
const account = getAccount(state, me); const account = getAccount(state, me);
const soapbox = getSoapboxConfig(state); const soapbox = getSoapboxConfig(state);
const features = getFeatures(state.instance);
return { return {
account, account,
features,
maxFields: state.getIn(['instance', 'pleroma', 'metadata', 'fields_limits', 'max_fields'], 4), maxFields: state.getIn(['instance', 'pleroma', 'metadata', 'fields_limits', 'max_fields'], 4),
verifiedCanEditName: soapbox.get('verifiedCanEditName'), verifiedCanEditName: soapbox.get('verifiedCanEditName'),
supportsEmailList: getFeatures(state.get('instance')).emailList,
}; };
}; };
@ -242,7 +243,7 @@ class EditProfile extends ImmutablePureComponent {
} }
render() { render() {
const { intl, account, verifiedCanEditName, supportsEmailList /* maxFields */ } = this.props; const { intl, account, verifiedCanEditName, features /* maxFields */ } = this.props;
const verified = account.get('verified'); const verified = account.get('verified');
const canEditName = verifiedCanEditName || !verified; const canEditName = verifiedCanEditName || !verified;
@ -262,6 +263,7 @@ class EditProfile extends ImmutablePureComponent {
/> />
</FormGroup> </FormGroup>
{features.accountLocation && (
<FormGroup <FormGroup
labelText={<FormattedMessage id='edit_profile.fields.location_label' defaultMessage='Location' />} labelText={<FormattedMessage id='edit_profile.fields.location_label' defaultMessage='Location' />}
> >
@ -272,7 +274,9 @@ class EditProfile extends ImmutablePureComponent {
placeholder={intl.formatMessage(messages.locationPlaceholder)} placeholder={intl.formatMessage(messages.locationPlaceholder)}
/> />
</FormGroup> </FormGroup>
)}
{features.accountWebsite && (
<FormGroup <FormGroup
labelText={<FormattedMessage id='edit_profile.fields.website_label' defaultMessage='Website' />} labelText={<FormattedMessage id='edit_profile.fields.website_label' defaultMessage='Website' />}
> >
@ -283,6 +287,7 @@ class EditProfile extends ImmutablePureComponent {
placeholder={intl.formatMessage(messages.websitePlaceholder)} placeholder={intl.formatMessage(messages.websitePlaceholder)}
/> />
</FormGroup> </FormGroup>
)}
<FormGroup <FormGroup
labelText={<FormattedMessage id='edit_profile.fields.bio_label' defaultMessage='Bio' />} labelText={<FormattedMessage id='edit_profile.fields.bio_label' defaultMessage='Bio' />}
@ -351,13 +356,15 @@ class EditProfile extends ImmutablePureComponent {
checked={this.state.discoverable} checked={this.state.discoverable}
onChange={this.handleCheckboxChange} onChange={this.handleCheckboxChange}
/>*/} />*/}
{supportsEmailList && <Checkbox {features.emailList && (
<Checkbox
label={<FormattedMessage id='edit_profile.fields.accepts_email_list_label' defaultMessage='Subscribe to newsletter' />} label={<FormattedMessage id='edit_profile.fields.accepts_email_list_label' defaultMessage='Subscribe to newsletter' />}
hint={<FormattedMessage id='edit_profile.hints.accepts_email_list' defaultMessage='Opt-in to news and marketing updates.' />} hint={<FormattedMessage id='edit_profile.hints.accepts_email_list' defaultMessage='Opt-in to news and marketing updates.' />}
name='accepts_email_list' name='accepts_email_list'
checked={this.state.accepts_email_list} checked={this.state.accepts_email_list}
onChange={this.handleCheckboxChange} onChange={this.handleCheckboxChange}
/>} />
)}
{/* </FieldsGroup> */} {/* </FieldsGroup> */}
{/*<FieldsGroup> {/*<FieldsGroup>
<div className='fields-row__column fields-group'> <div className='fields-row__column fields-group'>

View file

@ -142,6 +142,8 @@ const getInstanceFeatures = (instance: Instance) => {
trendingTruths: v.software === TRUTHSOCIAL, trendingTruths: v.software === TRUTHSOCIAL,
trendingStatuses: v.software === MASTODON && gte(v.compatVersion, '3.5.0'), trendingStatuses: v.software === MASTODON && gte(v.compatVersion, '3.5.0'),
pepe: v.software === TRUTHSOCIAL, pepe: v.software === TRUTHSOCIAL,
accountLocation: v.software === TRUTHSOCIAL,
accountWebsite: v.software === TRUTHSOCIAL,
// FIXME: long-term this shouldn't be a feature, // FIXME: long-term this shouldn't be a feature,
// but for now we want it to be overrideable in the build // but for now we want it to be overrideable in the build