import MultiLink from './MultiLink';
import Players from './Players';
import Icon from '../common/Icon';
-import { canRestreamEpisode } from '../../helpers/permissions';
+import { canApplyForEpisode, canRestreamEpisode } from '../../helpers/permissions';
import { withUser } from '../../helpers/UserContext';
const isActive = episode => {
return start.isBefore(now) && end.isAfter(now);
};
-const Item = ({ episode, onAddRestream, onEditRestream, user }) => {
+const Item = ({ episode, onAddRestream, onApply, onEditRestream, user }) => {
const { t } = useTranslation();
const classNames = [
classNames.push('is-active');
}
+ const style = React.useMemo(() => {
+ if (episode.event && episode.event.corner) {
+ return {
+ backgroundImage: `url(${episode.event.corner})`,
+ };
+ }
+ return null;
+ }, [episode.event && episode.event.corner]);
+
const hasChannels = episode.channels && episode.channels.length;
const hasPlayers = episode.players && episode.players.length;
- return <div className={classNames.join(' ')}>
+ return <div className={classNames.join(' ')} style={style}>
<div className="episode-start me-3 fs-4 text-end">
{t('schedule.startTime', { date: new Date(episode.start) })}
</div>
<div>
<Button
onClick={() => onAddRestream(episode)}
+ title={t('episodes.addRestream')}
variant="outline-secondary"
>
<Icon.ADD title="" />
- {' '}
- {t('episodes.addRestream')}
</Button>
</div>
: null}
{hasPlayers ?
<Players players={episode.players} />
: null}
- {episode.crew && episode.crew.length ?
- <Crew crew={episode.crew} />
+ {(episode.crew && episode.crew.length)
+ || canApplyForEpisode(user, episode, 'commentary')
+ || canApplyForEpisode(user, episode, 'tracking') ?
+ <Crew episode={episode} onApply={onApply} />
: null}
</div>
</div>;
crew: PropTypes.arrayOf(PropTypes.shape({
})),
event: PropTypes.shape({
+ corner: PropTypes.string,
title: PropTypes.string,
}),
players: PropTypes.arrayOf(PropTypes.shape({
title: PropTypes.string,
}),
onAddRestream: PropTypes.func,
+ onApply: PropTypes.func,
onEditRestream: PropTypes.func,
user: PropTypes.shape({
}),