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 Crew from './Crew';
8 import MultiLink from './MultiLink';
9 import Players from './Players';
11 const isActive = episode => {
12 if (!episode.start) return false;
14 const start = moment(episode.start).subtract(10, 'minutes');
15 const end = moment(episode.start).add(episode.estimate, 'seconds');
16 return start.isBefore(now) && end.isAfter(now);
19 const Item = ({ episode }) => {
20 const { t } = useTranslation();
31 if (isActive(episode)) {
32 classNames.push('is-active');
35 const hasChannels = episode.channels && episode.channels.length;
36 const hasPlayers = episode.players && episode.players.length;
38 return <div className={classNames.join(' ')}>
39 <div className="episode-start me-3 fs-4 text-end">
40 {t('schedule.startTime', { date: new Date(episode.start) })}
42 <div className="flex-fill">
43 <div className="d-flex align-items-start justify-content-between">
46 <div className="episode-title fs-4">
51 <div className="episode-event">
58 <Channels channels={episode.channels} />
60 {!hasChannels && hasPlayers ?
61 <MultiLink players={episode.players} />
66 <Players players={episode.players} />
68 {episode.crew && episode.crew.length ?
69 <Crew crew={episode.crew} />
76 episode: PropTypes.shape({
77 channels: PropTypes.arrayOf(PropTypes.shape({
79 crew: PropTypes.arrayOf(PropTypes.shape({
81 event: PropTypes.shape({
82 title: PropTypes.string,
84 players: PropTypes.arrayOf(PropTypes.shape({
86 start: PropTypes.string,
87 title: PropTypes.string,