'use client'; import React, { FC, useState, useEffect } from 'react'; import Image from 'next/image'; import { Tag, Image as AntdImage, Space, Button } from 'antd'; import { ZoomInOutlined, ZoomOutOutlined, StarFilled } from '@ant-design/icons'; import { SignupSessionData } from '../../types/experts'; import { ExpertDetails, Practice, ThemeGroup } from '../../types/experts'; import { ExpertDocument } from '../../types/file'; import { Locale } from '../../types/locale'; import { CustomRate } from '../view/CustomRate'; import { i18nText } from '../../i18nKeys'; import { FilledYellowButton } from '../view/FilledButton'; import { getStorageValue } from '../../hooks/useLocalStorage'; import { AUTH_TOKEN_KEY, SESSION_DATA } from '../../constants/common'; import { ScheduleModal } from '../Modals/ScheduleModal'; import { ScheduleModalResult } from '../Modals/ScheduleModalResult'; import SignalrConnection from '../../lib/signalr-connection'; import { useRouter } from '../../navigation'; import { useLocalStorage } from '../../hooks/useLocalStorage'; type ExpertDetailsProps = { expert: ExpertDetails; locale?: string; expertId?: string; }; type ExpertPracticeProps = { cases?: Practice[]; themes?: ThemeGroup[]; locale?: string; }; export const ExpertCard: FC = ({ expert, locale, expertId }) => { const { publicCoachDetails } = expert || {}; const [showSchedulerModal, setShowSchedulerModal] = useState(false); const [mode, setMode] = useState<'data' | 'time' | 'pay' | 'finish'>('data'); const isRus = locale === Locale.ru; const { publicCoachDetails: { tags = [], sessionCost = 0, sessionDuration = 0, coachLanguages = [] , id, botUserId} } = expert || {}; const [jwt] = useLocalStorage(AUTH_TOKEN_KEY, ''); const { joinChatPerson, closeConnection } = SignalrConnection(); const router = useRouter(); useEffect(() => { document?.addEventListener('show_pay_form', handleShowPayForm); return () => { closeConnection(); document?.removeEventListener('show_pay_form', handleShowPayForm); } }, []); const handleJoinChat = (id: number) => { joinChatPerson(id).then((res: any) => { router.push(`/account/messages/${res.id}` as string); }) } const checkSession = (data?: SignupSessionData) => { if (data?.startAtUtc && data?.tagId) { const jwt = getStorageValue(AUTH_TOKEN_KEY, ''); sessionStorage?.setItem(SESSION_DATA, JSON.stringify(data)); if (jwt) { setMode('pay'); } else { setShowSchedulerModal(false); const showAuth = new Event('show_auth_enter'); document?.dispatchEvent(showAuth); } } } const handleShowPayForm = () => { setShowSchedulerModal(true); setMode('pay'); } const onSchedulerHandle = () => { setMode('data'); setShowSchedulerModal(true); }; return ( <>

{`${publicCoachDetails?.name} ${publicCoachDetails?.surname || ''}`}

{`${publicCoachDetails?.practiceHours} ${i18nText('practiceHours', locale)}`} | {`${publicCoachDetails?.supervisionPerYearId} ${i18nText('supervisionCount', locale)}`}
} disabled /> {`4/5 (${i18nText('outOf', locale)} 345)`}
{jwt && (
{botUserId && ( )} {/* Video */}
)}
{/*

{}

*/}
{coachLanguages?.map((lang) => {lang})}
{/*

Hello, my name is Marcelo. I am a Senior UX Designer with more than 6 years of experience working with the largest companies in the world such as Disney, Globant and currently IBM. During my career, I have helped organizations solve complex problems using aesthetically pleasing designs with design while building teams and mentoring other designers. I can help you:
Prepare for interviews, prepare your resume or CV and work on your LinkedIn profile
Get ready for whiteboard challenges and take-home exercises
Create a great portfolio and case study presentation.
Provide industry information.
Professional orientation
Strategic thinking

Oh, and I also speak Spanish!

*/}
{tags?.map((skill) => {skill?.name})}
{i18nText('signUp', locale)}
{`${sessionCost}€`} / {`${sessionDuration}${isRus ? 'мин' : 'min'}`}
setShowSchedulerModal(false)} updateMode={setMode} mode={mode} expertId={expertId as string} locale={locale as string} sessionCost={sessionCost} checkSession={checkSession} /> ); }; export const ExpertPractice: FC = ({ themes = [], cases = [], locale }) => { return cases?.length > 0 ? (

{i18nText('successfulCase', locale)}

{cases?.map(({ id, description, themesGroupIds }) => { const filtered = themes ? themes.filter(({ id }) => themesGroupIds?.includes(+id)) : []; return (
{themesGroupIds && (
{filtered?.map(({ id, name }) => ( {name} ))}
)} {description &&

{description}

}
) })}
) : null; }; export const ExpertCertificate: FC<{ document: ExpertDocument }> = ({ document }) => ( )} fallback="" preview={{ src: document.fullSize?.url, toolbarRender: ( _, { transform: { scale }, actions: { onZoomOut, onZoomIn }, }, ) => ( ) }} /> );