'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>
            )
        }}
    />
);