import type { Author } from '../../graphql/types.gen' import Userpic from './Userpic' import { Icon } from '../_shared/Icon' import styles from './Card.module.scss' import { createMemo, createSignal, 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' import { StatMetrics } from '../_shared/StatMetrics' import { ShowOnlyOnClient } from '../_shared/ShowOnlyOnClient' import { FollowingEntity } from '../../graphql/types.gen' import { router, useRouter } from '../../stores/router' import { openPage } from '@nanostores/router' interface AuthorCardProps { caption?: string compact?: boolean hideDescription?: boolean hideFollow?: boolean hasLink?: boolean subscribed?: boolean author: Author isAuthorPage?: boolean noSocialButtons?: boolean isAuthorsList?: boolean truncateBio?: boolean liteButtons?: boolean isComments?: boolean isFeedMode?: boolean } export const AuthorCard = (props: AuthorCardProps) => { const { session, isSessionLoaded, actions: { loadSession } } = useSession() const [isSubscribing, setIsSubscribing] = createSignal(false) const subscribed = createMemo(() => { return session()?.news?.authors?.some((u) => u === props.author.slug) || false }) const subscribe = async (really = true) => { setIsSubscribing(true) await (really ? follow({ what: FollowingEntity.Author, slug: props.author.slug }) : unfollow({ what: FollowingEntity.Author, slug: props.author.slug })) await loadSession() setIsSubscribing(false) } const canFollow = createMemo(() => !props.hideFollow && session()?.user?.slug !== props.author.slug) const name = createMemo(() => { if (locale() !== 'ru') { if (props.author.name === 'Дискурс') { return 'Discours' } return translit(props.author.name) } return props.author.name }) // TODO: reimplement AuthorCard const { changeSearchParam } = useRouter() const initChat = () => { openPage(router, `inbox`) changeSearchParam('initChat', `${props.author.id}`) } return (
{name()}
{name()}
{props.isAuthorsList}
subscribe(true)} class={clsx('button', styles.button)} classList={{ [styles.buttonSubscribe]: !props.isAuthorsList, 'button--subscribe': !props.isAuthorsList, 'button--subscribe-topic': props.isAuthorsList, [styles.buttonWrite]: props.isAuthorsList, [styles.isSubscribing]: isSubscribing() }} disabled={isSubscribing()} > {t('Follow')} } >
{(link) => }
) }