import { For, Show } from 'solid-js/web' import type { Author } from '../../graphql/types.gen' import Userpic from './Userpic' import Icon from '../Nav/Icon' import './Card.scss' import { createMemo } from 'solid-js' import { translit } from '../../utils/ru2en' import { t } from '../../utils/intl' import { session } from '../../stores/auth' import { locale as locstore } from '../../stores/ui' import { follow, unfollow } from '../../stores/zine/common' import { useStore } from '@nanostores/solid' interface AuthorCardProps { compact?: boolean hideDescription?: boolean hideFollow?: boolean hasLink?: boolean subscribed?: boolean author: Author } export const AuthorCard = (props: AuthorCardProps) => { const locale = useStore(locstore) const auth = useStore(session) const subscribed = createMemo( () => !!auth() ?.info?.authors?.filter((u) => u === props.author.slug) .pop() ) const canFollow = createMemo(() => !props.hideFollow && auth()?.user?.slug !== props.author.slug) const bio = createMemo(() => props.author.bio || t('Our regular contributor')) const name = createMemo(() => { return props.author.name === 'Дискурс' && locale() !== 'ru' ? 'Discours' : translit(props.author.name || '', locale() || 'ru') }) // TODO: reimplement AuthorCard return ( <>
{name()}
{name()}
{bio()}
) }