Handle acct_full on the frontend

This commit is contained in:
Alex Gleason 2020-03-28 13:07:36 -05:00
parent 8458ce726c
commit 57d44889f2
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
5 changed files with 23 additions and 4 deletions

View file

@ -2,6 +2,7 @@ import React from 'react';
import ImmutablePropTypes from 'react-immutable-proptypes'; import ImmutablePropTypes from 'react-immutable-proptypes';
import PropTypes from 'prop-types'; import PropTypes from 'prop-types';
import VerificationBadge from './verification_badge'; import VerificationBadge from './verification_badge';
import { acctFull } from '../utils/accounts';
export default class DisplayName extends React.PureComponent { export default class DisplayName extends React.PureComponent {
@ -40,7 +41,7 @@ export default class DisplayName extends React.PureComponent {
{account.get('is_verified') && <VerificationBadge />} {account.get('is_verified') && <VerificationBadge />}
</> </>
); );
suffix = <span className='display-name__account'>@{account.get('acct_full')}</span>; suffix = <span className='display-name__account'>@{acctFull(account)}</span>;
} }
return ( return (

View file

@ -14,6 +14,7 @@ import ProBadge from 'gabsocial/components/pro_badge';
import DonorBadge from 'gabsocial/components/donor_badge'; import DonorBadge from 'gabsocial/components/donor_badge';
import InvestorBadge from 'gabsocial/components/investor_badge'; import InvestorBadge from 'gabsocial/components/investor_badge';
import { List as ImmutableList } from 'immutable'; import { List as ImmutableList } from 'immutable';
import { acctFull } from 'gabsocial/utils/accounts';
const messages = defineMessages({ const messages = defineMessages({
linkVerifiedOn: { id: 'account.link_verified_on', defaultMessage: 'Ownership of this link was checked on {date}' }, linkVerifiedOn: { id: 'account.link_verified_on', defaultMessage: 'Ownership of this link was checked on {date}' },
@ -73,7 +74,7 @@ class ProfileInfoPanel extends ImmutablePureComponent {
<span dangerouslySetInnerHTML={displayNameHtml} /> <span dangerouslySetInnerHTML={displayNameHtml} />
{account.get('is_verified') && <VerificationBadge />} {account.get('is_verified') && <VerificationBadge />}
{badge} {badge}
<small>@{account.get('acct_full')} {lockedIcon}</small> <small>@{acctFull(account)} {lockedIcon}</small>
</h1> </h1>
</div> </div>

View file

@ -9,6 +9,7 @@ import ImmutablePropTypes from 'react-immutable-proptypes';
import ImmutablePureComponent from 'react-immutable-pure-component'; import ImmutablePureComponent from 'react-immutable-pure-component';
import Avatar from 'gabsocial/components/avatar'; import Avatar from 'gabsocial/components/avatar';
import { shortNumberFormat } from 'gabsocial/utils/numbers'; import { shortNumberFormat } from 'gabsocial/utils/numbers';
import { acctFull } from 'gabsocial/utils/accounts';
class UserPanel extends ImmutablePureComponent { class UserPanel extends ImmutablePureComponent {
static propTypes = { static propTypes = {
@ -42,7 +43,7 @@ class UserPanel extends ImmutablePureComponent {
<h1> <h1>
<Link to={`/@${account.get('acct')}`}> <Link to={`/@${account.get('acct')}`}>
<span className='user-panel__account__name' dangerouslySetInnerHTML={displayNameHtml} /> <span className='user-panel__account__name' dangerouslySetInnerHTML={displayNameHtml} />
<small className='user-panel__account__username'>@{account.get('acct_full')}</small> <small className='user-panel__account__username'>@{acctFull(account)}</small>
</Link> </Link>
</h1> </h1>
</div> </div>

View file

@ -0,0 +1,16 @@
const getDomain = account => {
let re = /https?:\/\/(.*?)\//i;
return re.exec(account.get('url'))[1];
}
// user@domain even for local users
export const acctFull = account => {
let [user, domain] = account.get('acct').split('@');
try {
if (!domain) domain = getDomain(account);
} catch(e) {
console.error('Could not get domain for acctFull.');
return account.get('acct');
}
return [user, domain].join('@');
}

File diff suppressed because one or more lines are too long