+ 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(' ')} style={style}>
+ <div className="d-flex align-items-stretch">
+ <div className="episode-start me-3 fs-5 fs-md-4 text-end">
+ {t('schedule.startTime', { date: new Date(episode.start) })}
+ </div>
+ <div className="episode-titlebar">
+ {episode.title || episode.event ?
+ <div className="episode-title fs-5 fs-md-4">
+ {episode.title || episode.event.title}
+ </div>
+ : null}
+ {episode.comment ?
+ <div className="episode-comment">
+ {episode.comment}
+ </div>
+ : null}
+ </div>
+ <div className="episode-channel-links ms-auto text-end">
+ {hasChannels ?
+ <Channels
+ channels={episode.channels}
+ episode={episode}
+ onEditRestream={onEditRestream}
+ />
+ : null}
+ {!hasChannels && hasPlayers ?
+ <MultiLink players={episode.players} />
+ : null}
+ {episode.raceroom ?
+ <div>
+ <Button
+ href={episode.raceroom}
+ target="_blank"
+ title={t('episodes.raceroom')}
+ variant="outline-secondary"
+ >
+ <Icon.RACETIME title="" />
+ {' '}
+ {t('episodes.raceroom')}
+ </Button>
+ </div>
+ : null}
+ {onAddRestream && canRestreamEpisode(user, episode) ?
+ <div>
+ <Button
+ onClick={() => onAddRestream(episode)}
+ title={t('episodes.addRestream')}
+ variant="outline-secondary"
+ >
+ <Icon.ADD title="" />
+ </Button>
+ </div>
+ : null}
+ </div>