mirror of
https://github.com/LemmyNet/lemmy-ui.git
synced 2025-01-24 10:55:50 +00:00
Merge branch 'main' into content-warning
This commit is contained in:
commit
f97f3960fa
2 changed files with 45 additions and 62 deletions
|
@ -20,42 +20,38 @@ export class CommunityLink extends Component<CommunityLinkProps, any> {
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const community = this.props.community;
|
const { community, useApubName } = this.props;
|
||||||
let title: string, link: string;
|
|
||||||
const local = community.local === null ? true : community.local;
|
const local = community.local === null ? true : community.local;
|
||||||
const domain = hostname(community.actor_id);
|
|
||||||
|
let link: string;
|
||||||
|
let serverStr: string | undefined = undefined;
|
||||||
|
|
||||||
|
const title = useApubName
|
||||||
|
? community.name
|
||||||
|
: community.title ?? community.name;
|
||||||
|
|
||||||
if (local) {
|
if (local) {
|
||||||
title = community.title;
|
|
||||||
link = `/c/${community.name}`;
|
link = `/c/${community.name}`;
|
||||||
} else {
|
} else {
|
||||||
const name_ = `${community.name}@${domain}`;
|
serverStr = `@${hostname(community.actor_id)}`;
|
||||||
title = `${community.title}@${domain}`;
|
link = !this.props.realLink
|
||||||
link = !this.props.realLink ? `/c/${name_}` : community.actor_id;
|
? `/c/${community.name}${serverStr}`
|
||||||
|
: community.actor_id;
|
||||||
}
|
}
|
||||||
|
const classes = `community-link ${this.props.muted ? "text-muted" : ""}`;
|
||||||
|
|
||||||
const apubName = `!${community.name}@${domain}`;
|
|
||||||
const displayName = this.props.useApubName ? apubName : title;
|
|
||||||
return !this.props.realLink ? (
|
return !this.props.realLink ? (
|
||||||
<Link
|
<Link title={title} className={classes} to={link}>
|
||||||
title={apubName}
|
{this.avatarAndName(title, serverStr)}
|
||||||
className={`community-link ${this.props.muted ? "text-muted" : ""}`}
|
|
||||||
to={link}
|
|
||||||
>
|
|
||||||
{this.avatarAndName(displayName)}
|
|
||||||
</Link>
|
</Link>
|
||||||
) : (
|
) : (
|
||||||
<a
|
<a title={title} className={classes} href={link} rel={relTags}>
|
||||||
title={apubName}
|
{this.avatarAndName(title, serverStr)}
|
||||||
className={`community-link ${this.props.muted ? "text-muted" : ""}`}
|
|
||||||
href={link}
|
|
||||||
rel={relTags}
|
|
||||||
>
|
|
||||||
{this.avatarAndName(displayName)}
|
|
||||||
</a>
|
</a>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
avatarAndName(displayName: string) {
|
avatarAndName(title: string, serverStr?: string) {
|
||||||
const icon = this.props.community.icon;
|
const icon = this.props.community.icon;
|
||||||
const nsfw = this.props.community.nsfw;
|
const nsfw = this.props.community.nsfw;
|
||||||
|
|
||||||
|
@ -65,7 +61,10 @@ export class CommunityLink extends Component<CommunityLinkProps, any> {
|
||||||
!this.props.community.removed &&
|
!this.props.community.removed &&
|
||||||
showAvatars() &&
|
showAvatars() &&
|
||||||
icon && <PictrsImage src={icon} icon nsfw={nsfw} />}
|
icon && <PictrsImage src={icon} icon nsfw={nsfw} />}
|
||||||
<span className="overflow-wrap-anywhere">{displayName}</span>
|
<span className="overflow-wrap-anywhere">
|
||||||
|
{title}
|
||||||
|
{serverStr && <small className="text-muted">{serverStr}</small>}
|
||||||
|
</span>
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,64 +24,47 @@ export class PersonListing extends Component<PersonListingProps, any> {
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const person = this.props.person;
|
const { person, useApubName } = this.props;
|
||||||
const local = person.local;
|
const local = person.local;
|
||||||
let apubName: string, link: string;
|
let link: string;
|
||||||
|
let serverStr: string | undefined = undefined;
|
||||||
|
|
||||||
|
const name = useApubName ? person.name : person.display_name ?? person.name;
|
||||||
|
|
||||||
if (local) {
|
if (local) {
|
||||||
apubName = `@${person.name}`;
|
|
||||||
link = `/u/${person.name}`;
|
link = `/u/${person.name}`;
|
||||||
} else {
|
} else {
|
||||||
const domain = hostname(person.actor_id);
|
serverStr = `@${hostname(person.actor_id)}`;
|
||||||
apubName = `@${person.name}@${domain}`;
|
|
||||||
link = !this.props.realLink
|
link = !this.props.realLink
|
||||||
? `/u/${person.name}@${domain}`
|
? `/u/${person.name}${serverStr}`
|
||||||
: person.actor_id;
|
: person.actor_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
let displayName = this.props.useApubName
|
const classes = classNames(
|
||||||
? apubName
|
|
||||||
: person.display_name ?? apubName;
|
|
||||||
|
|
||||||
if (this.props.showApubName && !local && person.display_name) {
|
|
||||||
displayName = `${displayName} (${apubName})`;
|
|
||||||
}
|
|
||||||
|
|
||||||
return (
|
|
||||||
<>
|
|
||||||
{!this.props.realLink ? (
|
|
||||||
<Link
|
|
||||||
title={apubName}
|
|
||||||
className={classNames(
|
|
||||||
"person-listing d-inline-flex align-items-baseline",
|
"person-listing d-inline-flex align-items-baseline",
|
||||||
{
|
{
|
||||||
"text-muted": this.props.muted,
|
"text-muted": this.props.muted,
|
||||||
"text-info": !this.props.muted,
|
"text-info": !this.props.muted,
|
||||||
},
|
},
|
||||||
)}
|
);
|
||||||
to={link}
|
return (
|
||||||
>
|
<>
|
||||||
{this.avatarAndName(displayName)}
|
{!this.props.realLink ? (
|
||||||
|
<Link title={name} className={classes} to={link}>
|
||||||
|
{this.avatarAndName(name, serverStr)}
|
||||||
</Link>
|
</Link>
|
||||||
) : (
|
) : (
|
||||||
<a
|
<a title={name} className={classes} href={link} rel={relTags}>
|
||||||
title={apubName}
|
{this.avatarAndName(name, serverStr)}
|
||||||
className={`person-listing d-inline-flex align-items-baseline ${
|
|
||||||
this.props.muted ? "text-muted" : "text-info"
|
|
||||||
}`}
|
|
||||||
href={link}
|
|
||||||
rel={relTags}
|
|
||||||
>
|
|
||||||
{this.avatarAndName(displayName)}
|
|
||||||
</a>
|
</a>
|
||||||
)}
|
)}
|
||||||
|
|
||||||
{isCakeDay(person.published) && <CakeDay creatorName={apubName} />}
|
{isCakeDay(person.published) && <CakeDay creatorName={name} />}
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
avatarAndName(displayName: string) {
|
avatarAndName(name: string, serverStr?: string) {
|
||||||
const avatar = this.props.person.avatar;
|
const avatar = this.props.person.avatar;
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
|
@ -93,7 +76,8 @@ export class PersonListing extends Component<PersonListingProps, any> {
|
||||||
icon
|
icon
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
<span>{displayName}</span>
|
<span>{name}</span>
|
||||||
|
{serverStr && <small className="text-muted">{serverStr}</small>}
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue