'use client'; import React, { useCallback, useEffect, useState } from 'react'; import styled from 'styled-components'; import dayjs from 'dayjs'; import 'dayjs/locale/ru'; import 'dayjs/locale/en'; import 'dayjs/locale/de'; import 'dayjs/locale/it'; import 'dayjs/locale/fr'; import 'dayjs/locale/es'; import { CustomSelect, Loader } from '../view'; import { useLocalStorage } from '../../hooks/useLocalStorage'; import { AUTH_TOKEN_KEY, AUTH_USER } from '../../constants/common'; import { getRecentSessions, getRequestedSessions, getUpcomingSessions } from '../../actions/profile'; import { Session, Sessions, SessionType } from '../../types/sessions'; const Tab = styled.div``; export const SessionsTabs = ({ intlConfig, locale }: { intlConfig: Record, locale: string }) => { const [activeTab, setActiveTab] = useState(0); const [sort, setSort] = useState(); const [sessions, setSessions] = useState(); const [loading, setLoading] = useState(true); const [errorData, setErrorData] = useState(); const [jwt] = useLocalStorage(AUTH_TOKEN_KEY, ''); const [userId] = useLocalStorage(AUTH_USER, ''); const fetchData = () => { setErrorData(undefined); setLoading(true); Promise.all([ getUpcomingSessions(locale, jwt), getRequestedSessions(locale, jwt), getRecentSessions(locale, jwt) ]) .then(([upcoming, requested, recent]) => { setSessions({ [SessionType.UPCOMING]: upcoming.data || [], [SessionType.REQUESTED]: requested.data?.requestedSessions || [], [SessionType.RECENT]: recent.data || [] }); }) .catch((err) => { setErrorData(err); }) .finally(() => { setLoading(false); }); }; useEffect(() => { fetchData(); }, []); const onChangeSort = useCallback((value: string) => { setSort(value); }, [sort]); const getChildren = (list?: Session[]) => ( <>
{list && list?.length > 0 ? list?.map(({ id, scheduledStartAtUtc, scheduledEndAtUtc, title, coach, clients }) => { const client = clients?.length ? clients[0] : null; const current = +userId !== client?.id ? client : coach; const startDate = dayjs(scheduledStartAtUtc).locale(locale); const endDate = dayjs(scheduledEndAtUtc).locale(locale); const today = dayjs().format('YYYY-MM-DD') === startDate.format('YYYY-MM-DD'); return (
{`${current?.name} ${current?.surname || ''}`}
{title}
{today ? `Today ${startDate.format('HH:mm')} - ${endDate.format('HH:mm')}` : `${startDate.format('D MMMM')} ${startDate.format('HH:mm')} - ${endDate.format('HH:mm')}`}
) }) : (
not found
)}
); const tabs = [ { key: SessionType.UPCOMING, label: ( <> {intlConfig?.upcoming || 'Tab 1'} {sessions?.upcoming?.length > 0 ? ({sessions?.upcoming.length}) : null} ), children: getChildren(sessions?.upcoming) }, { key: SessionType.REQUESTED, label: ( <> {intlConfig?.requested || 'Tab 2'} {sessions?.requested?.length > 0 ? ({sessions?.requested.length}) : null} ), children: getChildren(sessions?.requested) }, { key: SessionType.RECENT, label: intlConfig?.recent || 'Tab 3', children: getChildren(sessions?.recent) } ]; return (
{tabs.map((tab, index) => ( setActiveTab(index)} > {tab.label} ))}
{tabs[activeTab].children}
); };