import type { Author } from '../../graphql/types.gen' import Userpic from './Userpic' import { Icon } from '../_shared/Icon' import styles from './Card.module.scss' import { createMemo, For, Show } from 'solid-js' import { translit } from '../../utils/ru2en' import { t } from '../../utils/intl' import { locale } from '../../stores/ui' import { follow, unfollow } from '../../stores/zine/common' import { clsx } from 'clsx' import { useSession } from '../../context/session' interface AuthorCardProps { compact?: boolean hideDescription?: boolean hideFollow?: boolean hasLink?: boolean subscribed?: boolean author: Author isAuthorPage?: boolean noSocialButtons?: boolean isAuthorsList?: boolean truncateBio?: boolean } export const AuthorCard = (props: AuthorCardProps) => { const { session } = useSession() const subscribed = createMemo( () => session()?.news?.authors?.some((u) => u === props.author.slug) || false ) const canFollow = createMemo(() => !props.hideFollow && session()?.user?.slug !== props.author.slug) const bio = () => { const d = document.createElement('div') d.innerHTML = props.author.bio return d.innerText || t('Our regular contributor') } const name = () => { return props.author.name === 'Дискурс' && locale() !== 'ru' ? 'Discours' : translit(props.author.name || '', locale() || 'ru') } // TODO: reimplement AuthorCard return (
{name()}
{name()}
{props.isAuthorsList}
{bio()}
follow} class={clsx('button', styles.button)} classList={{ [styles.buttonSubscribe]: !props.isAuthorsList, 'button--subscribe': !props.isAuthorsList, 'button--subscribe-topic': props.isAuthorsList, [styles.buttonWrite]: props.isAuthorsList }} > {t('Follow')} } > {(link) => }
) }