import { Component } from 'inferno'; import { Link } from 'inferno-router'; import { CommunitySafe } from 'lemmy-js-client'; import { hostname, showAvatars } from '../utils'; import { PictrsImage } from './pictrs-image'; interface CommunityLinkProps { // TODO figure this out better community: CommunitySafe; realLink?: boolean; useApubName?: boolean; muted?: boolean; hideAvatar?: boolean; } export class CommunityLink extends Component { constructor(props: any, context: any) { super(props, context); } render() { let community = this.props.community; let name_: string, link: string; let local = community.local == null ? true : community.local; if (local) { name_ = community.name; link = `/c/${community.name}`; } else { name_ = `${community.name}@${hostname(community.actor_id)}`; link = !this.props.realLink ? `/community/${community.id}` : community.actor_id; } let apubName = `!${name_}`; let displayName = this.props.useApubName ? apubName : name_; return ( {!this.props.hideAvatar && community.icon && showAvatars() && ( )} {displayName} ); } }