-import moment from 'moment';
import PropTypes from 'prop-types';
import React from 'react';
import { Button } from 'react-bootstrap';
import { useTranslation } from 'react-i18next';
+import { Link } from 'react-router-dom';
import Channels from './Channels';
import Crew from './Crew';
import MultiLink from './MultiLink';
import Players from './Players';
import Icon from '../common/Icon';
+import { hasPassed, hasSGRestream, isActive } from '../../helpers/Episode';
import { canApplyForEpisode, canRestreamEpisode } from '../../helpers/permissions';
import { withUser } from '../../helpers/UserContext';
-const isActive = episode => {
- if (!episode.start) return false;
- const now = moment();
- const start = moment(episode.start).subtract(10, 'minutes');
- const end = moment(episode.start).add(episode.estimate, 'seconds');
- return start.isBefore(now) && end.isAfter(now);
-};
-
const Item = ({ episode, onAddRestream, onApply, onEditRestream, user }) => {
const { t } = useTranslation();
<div className="d-flex flex-column flex-fill">
<div className="d-flex align-items-start justify-content-between">
<div>
- {episode.title ?
+ {episode.title || episode.event ?
<div className="episode-title fs-4">
- {episode.title}
+ {episode.title || episode.event.title}
</div>
: null}
{episode.comment ?
{hasPlayers ?
<Players players={episode.players} />
: null}
- {(episode.crew && episode.crew.length)
+ {(episode.crew && episode.crew.length) || (!hasPassed(episode) && (
+ hasSGRestream(episode)
|| canApplyForEpisode(user, episode, 'commentary')
- || canApplyForEpisode(user, episode, 'tracking') ?
+ || canApplyForEpisode(user, episode, 'tracking')
+ )) ?
<div className="mb-3">
<Crew episode={episode} onApply={onApply} />
</div>
: null}
{episode.event ?
<div className="episode-event mt-auto">
- {episode.event.title}
+ {episode.event.description_id ?
+ <Link className="event-link" to={`/events/${episode.event.name}`}>
+ {episode.event.title}
+ </Link>
+ :
+ episode.event.title
+ }
</div>
: null}
</div>
})),
event: PropTypes.shape({
corner: PropTypes.string,
+ description_id: PropTypes.number,
+ name: PropTypes.string,
title: PropTypes.string,
}),
players: PropTypes.arrayOf(PropTypes.shape({