X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=resources%2Fjs%2Fcomponents%2Fepisodes%2FItem.js;h=9acb95d29859b0bb6242312edccb333c8918061b;hb=c01ebf99d629029288a2ea7cf6874ca076d87f70;hp=5f43c1248b15fb1df75f6c39477f7dfe223baaf7;hpb=9b4ede72755930de6b0a39bf6f142e598c043844;p=alttp.git diff --git a/resources/js/components/episodes/Item.js b/resources/js/components/episodes/Item.js index 5f43c12..9acb95d 100644 --- a/resources/js/components/episodes/Item.js +++ b/resources/js/components/episodes/Item.js @@ -9,7 +9,7 @@ import Crew from './Crew'; 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 => { @@ -20,13 +20,13 @@ 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 = [ 'episodes-item', 'd-flex', - 'align-items-start', + 'align-items-stretch', 'my-3', 'p-2', 'border', @@ -52,17 +52,17 @@ const Item = ({ episode, onAddRestream, onEditRestream, user }) => {
{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}
@@ -81,11 +81,10 @@ const Item = ({ episode, onAddRestream, onEditRestream, user }) => {
: null} @@ -94,8 +93,17 @@ const Item = ({ episode, onAddRestream, onEditRestream, user }) => { {hasPlayers ? : null} - {episode.crew && episode.crew.length ? - + {(episode.crew && episode.crew.length) + || canApplyForEpisode(user, episode, 'commentary') + || canApplyForEpisode(user, episode, 'tracking') ? +
+ +
+ : null} + {episode.event ? +
+ {episode.event.title} +
: null}
; @@ -105,6 +113,7 @@ Item.propTypes = { episode: PropTypes.shape({ channels: PropTypes.arrayOf(PropTypes.shape({ })), + comment: PropTypes.string, crew: PropTypes.arrayOf(PropTypes.shape({ })), event: PropTypes.shape({ @@ -117,6 +126,7 @@ Item.propTypes = { title: PropTypes.string, }), onAddRestream: PropTypes.func, + onApply: PropTypes.func, onEditRestream: PropTypes.func, user: PropTypes.shape({ }),