+import moment from 'moment';
import PropTypes from 'prop-types';
import React from 'react';
import { useTranslation } from 'react-i18next';
+import Channels from './Channels';
import Players from './Players';
+const isActive = episode => {
+ if (!episode.start) return false;
+ const now = moment();
+ const start = moment(episode.start);
+ const end = moment(start).add(episode.estimate, 'seconds');
+ return start.isBefore(now) && end.isAfter(now);
+};
+
const Item = ({ episode }) => {
const { t } = useTranslation();
- return <div className="episodes-item d-flex align-items-start my-3 p-2 border rounded">
+ const classNames = [
+ 'episodes-item',
+ 'd-flex',
+ 'align-items-start',
+ 'my-3',
+ 'p-2',
+ 'border',
+ 'rounded',
+ ];
+ if (isActive(episode)) {
+ classNames.push('is-active');
+ }
+
+ return <div className={classNames.join(' ')}>
<div className="episode-start me-3 fs-4 text-end">
{t('schedule.startTime', { date: new Date(episode.start) })}
</div>
<div className="flex-fill">
- {episode.title ?
- <div className="episode-title fs-4">
- {episode.title}
+ <div className="d-flex align-items-start justify-content-between">
+ <div>
+ {episode.title ?
+ <div className="episode-title fs-4">
+ {episode.title}
+ </div>
+ : null}
+ {episode.event ?
+ <div className="episode-event">
+ {episode.event.title}
+ </div>
+ : null}
</div>
- : null}
- {episode.event ?
- <div className="episode-event">
- {episode.event.title}
+ <div>
+ {episode.channels ?
+ <Channels channels={episode.channels} />
+ : null}
</div>
+ </div>
+ {episode.players ?
+ <Players players={episode.players} />
: null}
- <Players players={episode.players} />
</div>
</div>;
};
Item.propTypes = {
episode: PropTypes.shape({
+ channels: PropTypes.arrayOf(PropTypes.shape({
+ })),
event: PropTypes.shape({
title: PropTypes.string,
}),