1 import moment from 'moment';
2 import PropTypes from 'prop-types';
3 import React from 'react';
4 import { useTranslation } from 'react-i18next';
6 import Channels from './Channels';
7 import Players from './Players';
9 const isActive = episode => {
10 if (!episode.start) return false;
12 const start = moment(episode.start);
13 const end = moment(start).add(episode.estimate, 'seconds');
14 return start.isBefore(now) && end.isAfter(now);
17 const Item = ({ episode }) => {
18 const { t } = useTranslation();
29 if (isActive(episode)) {
30 classNames.push('is-active');
33 return <div className={classNames.join(' ')}>
34 <div className="episode-start me-3 fs-4 text-end">
35 {t('schedule.startTime', { date: new Date(episode.start) })}
37 <div className="flex-fill">
38 <div className="d-flex align-items-start justify-content-between">
41 <div className="episode-title fs-4">
46 <div className="episode-event">
53 <Channels channels={episode.channels} />
58 <Players players={episode.players} />
65 episode: PropTypes.shape({
66 channels: PropTypes.arrayOf(PropTypes.shape({
68 event: PropTypes.shape({
69 title: PropTypes.string,
71 players: PropTypes.arrayOf(PropTypes.shape({
73 start: PropTypes.string,
74 title: PropTypes.string,