'use client'; import React, { FC } from 'react'; import Image from 'next/image'; import { Tag, Image as AntdImage, Space } from 'antd'; import { ZoomInOutlined, ZoomOutOutlined, StarFilled } from '@ant-design/icons'; import { ExpertDetails, ExpertDocument } from '../../types/experts'; import { Locale } from '../../types/locale'; import { CustomRate } from '../view/CustomRate'; import { i18nText } from '../../i18nKeys'; import { FilledYellowButton } from '../view/FilledButton'; type ExpertDetailsProps = { expert: ExpertDetails; locale?: string; }; export const ExpertCard: FC<ExpertDetailsProps> = ({ expert, locale }) => { const { publicCoachDetails } = expert || {}; return ( <div className="expert-card"> <div className="expert-card__wrap"> <div className="expert-card__avatar"> <Image src={publicCoachDetails?.faceImageUrl || '/images/person.png'} width={216} height={216} alt="" /> </div> <div className="expert-card__inner"> <h1 className="expert-card__title">{`${publicCoachDetails?.name} ${publicCoachDetails?.surname || ''}`}</h1> <div className="expert-card__info"> <span>{`${publicCoachDetails?.practiceHours} ${i18nText('practiceHours', locale)}`}</span> <i>|</i> <span>{`${publicCoachDetails?.supervisionPerYearId} ${i18nText('supervisionCount', locale)}`}</span> </div> <div className="expert-card__rating"> <CustomRate defaultValue={4} character={<StarFilled style={{ fontSize: 32 }} />} disabled /> <span>{`4/5 (${i18nText('outOf', locale)} 345)`}</span> </div> </div> </div> <div className="expert-card__wrap-btn"> <a href="#" className="btn-apply"> <img src="/images/calendar-outline.svg" className="" alt="" /> {i18nText('schedule', locale)} </a> {/* <a href="#" className="btn-video"> <img src="/images/videocam-outline.svg" className="" alt=""/> Video </a> */} </div> </div> ); }; export const ExpertInformation: FC<ExpertDetailsProps> = ({ expert, locale }) => { const { publicCoachDetails: { tags = [], sessionCost = 0, sessionDuration = 0, coachLanguages = [] } } = expert || {}; const isRus = locale === Locale.ru; return ( <> <div className="expert-info"> {/* <h2 className="title-h2">{}</h2> */} <div className="skills__list"> {coachLanguages?.map((skill) => <Tag key={skill} className="skills__list__item">{skill}</Tag>)} </div> </div> <p className="base-text"> 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: <br /> Prepare for interviews, prepare your resume or CV and work on your LinkedIn profile <br /> Get ready for whiteboard challenges and take-home exercises <br /> Create a great portfolio and case study presentation. <br /> Provide industry information. <br /> Professional orientation <br /> Strategic thinking <br /><br /> Oh, and I also speak Spanish! </p> <div className="skills__list"> {tags?.map((skill) => <Tag key={skill?.id} className="skills__list__item">{skill?.name}</Tag>)} </div> <div className="wrap-btn-prise"> <FilledYellowButton onClick={() => console.log('schedule')}>{i18nText('signUp', locale)}</FilledYellowButton> <div className="wrap-btn-prise__text"> {`${sessionCost}€`} <span>/ {`${sessionDuration}${isRus ? 'мин' : 'min'}`}</span> </div> </div> </> ); }; export const ExpertPractice: FC<ExpertDetailsProps> = ({ expert, locale }) => { const { publicCoachDetails: { practiceCases = [], themesGroups = [] } } = expert || {}; return practiceCases?.length > 0 ? ( <div> <h3 className="title-h3">{i18nText('successfulCase', locale)}</h3> {practiceCases?.map(({ id, description, themesGroupIds }) => { const filtered = themesGroups?.filter(({ id }) => themesGroupIds?.includes(+id)); return ( <div key={id} className="case-list"> {themesGroupIds && ( <div className="skills__list"> {filtered?.map(({ id, name }) => ( <Tag key={id} className="skills__list__item">{name}</Tag> ))} </div> )} {description && <p className="base-text">{description}</p>} </div> ) })} </div> ) : null; }; export const ExpertCertificate: FC<{ document: ExpertDocument }> = ({ document }) => ( <AntdImage width={160} src={document?.preview?.url} placeholder={( <AntdImage preview={false} src={document?.preview?.url} width={160} fallback="" /> )} fallback="" preview={{ src: document.fullSize?.url, toolbarRender: ( _, { transform: { scale }, actions: { onZoomOut, onZoomIn }, }, ) => ( <Space size={12} className="toolbar-wrapper"> <ZoomOutOutlined disabled={scale === 1} onClick={onZoomOut} /> <ZoomInOutlined disabled={scale === 50} onClick={onZoomIn} /> </Space> ) }} /> );