X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=resources%2Fjs%2Fcomponents%2Fepisodes%2FItem.js;h=03cb6febd827301ff7d0a8442a11044b3e95f23a;hb=a0bca4306e882d77ba192eed889bd7ed52896dad;hp=2078c6dc6573bb74f554032ae67a3fdc0323cd3d;hpb=e2af94795e9d8e8a2eb8c272201b4e54ebb130f0;p=alttp.git
diff --git a/resources/js/components/episodes/Item.js b/resources/js/components/episodes/Item.js
index 2078c6d..03cb6fe 100644
--- a/resources/js/components/episodes/Item.js
+++ b/resources/js/components/episodes/Item.js
@@ -1,27 +1,25 @@
-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);
- const end = moment(start).add(episode.estimate, 'seconds');
- return start.isBefore(now) && end.isAfter(now);
-};
-
-const Item = ({ episode }) => {
+const Item = ({ episode, onAddRestream, onApply, onEditRestream, user }) => {
const { t } = useTranslation();
const classNames = [
'episodes-item',
'd-flex',
- 'align-items-start',
+ 'align-items-stretch',
'my-3',
'p-2',
'border',
@@ -31,35 +29,82 @@ const Item = ({ episode }) => {
classNames.push('is-active');
}
- return
+ 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
{t('schedule.startTime', { date: new Date(episode.start) })}
-
+
- {episode.title ?
+ {episode.title || episode.event ?
- {episode.title}
+ {episode.title || episode.event.title}
: null}
- {episode.event ?
-
- {episode.event.title}
+ {episode.comment ?
+
+ {episode.comment}
: null}
-
- {episode.channels ?
-
+
+ {hasChannels ?
+
+ : null}
+ {!hasChannels && hasPlayers ?
+
+ : null}
+ {onAddRestream && canRestreamEpisode(user, episode) ?
+
+
+
: null}
- {episode.players && episode.players.length ?
+ {hasPlayers ?
: null}
- {episode.crew && episode.crew.length ?
-
+ {(episode.crew && episode.crew.length) || (!hasPassed(episode) && (
+ hasSGRestream(episode)
+ || canApplyForEpisode(user, episode, 'commentary')
+ || canApplyForEpisode(user, episode, 'tracking')
+ )) ?
+
+
+
+ : null}
+ {episode.event ?
+
+ {episode.event.description_id ?
+
+ {episode.event.title}
+
+ :
+ episode.event.title
+ }
+
: null}
;
@@ -69,9 +114,13 @@ Item.propTypes = {
episode: PropTypes.shape({
channels: PropTypes.arrayOf(PropTypes.shape({
})),
+ comment: PropTypes.string,
crew: PropTypes.arrayOf(PropTypes.shape({
})),
event: PropTypes.shape({
+ corner: PropTypes.string,
+ description_id: PropTypes.number,
+ name: PropTypes.string,
title: PropTypes.string,
}),
players: PropTypes.arrayOf(PropTypes.shape({
@@ -79,6 +128,11 @@ Item.propTypes = {
start: PropTypes.string,
title: PropTypes.string,
}),
+ onAddRestream: PropTypes.func,
+ onApply: PropTypes.func,
+ onEditRestream: PropTypes.func,
+ user: PropTypes.shape({
+ }),
};
-export default Item;
+export default withUser(Item);