X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=resources%2Fjs%2Fcomponents%2Fepisodes%2FItem.js;h=adb710916a088ba8730f89912ba3e643918a06d5;hb=a5d038197b7a31c2d354fed242985cb604c4f8a8;hp=d7c4bab4ff7d68245e87ff84f5a3cabe243fb554;hpb=0a2bb2069cee683d525596dfe0141cac60f0f977;p=alttp.git diff --git a/resources/js/components/episodes/Item.js b/resources/js/components/episodes/Item.js index d7c4bab..adb7109 100644 --- a/resources/js/components/episodes/Item.js +++ b/resources/js/components/episodes/Item.js @@ -1,4 +1,3 @@ -import moment from 'moment'; import PropTypes from 'prop-types'; import React from 'react'; import { Button } from 'react-bootstrap'; @@ -10,24 +9,15 @@ 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(); const classNames = [ 'episodes-item', - 'd-flex', - 'align-items-stretch', 'my-3', 'p-2', 'border', @@ -50,62 +40,68 @@ const Item = ({ episode, onAddRestream, onApply, onEditRestream, user }) => { const hasPlayers = episode.players && episode.players.length; return
-
- {t('schedule.startTime', { date: new Date(episode.start) })} -
-
-
-
- {episode.title || episode.event ? -
- {episode.title || episode.event.title} -
- : null} - {episode.comment ? -
- {episode.comment} -
- : null} -
-
- {hasChannels ? - - : null} - {!hasChannels && hasPlayers ? - - : null} - {onAddRestream && canRestreamEpisode(user, episode) ? -
- -
- : null} -
+
+
+ {t('schedule.startTime', { date: new Date(episode.start) })} +
+
+ {episode.title || episode.event ? +
+ {episode.title || episode.event.title} +
+ : null} + {episode.comment ? +
+ {episode.comment} +
+ : null}
+
+ {hasChannels ? + + : null} + {!hasChannels && hasPlayers ? + + : null} + {onAddRestream && canRestreamEpisode(user, episode) ? +
+ +
+ : null} +
+
+
{hasPlayers ? : 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') + )) ?
: null} {episode.event ?
- - {episode.event.title} - + {episode.event.description_id ? + + {episode.event.title} + + : + episode.event.title + }
: null}
@@ -121,6 +117,7 @@ Item.propTypes = { })), event: PropTypes.shape({ corner: PropTypes.string, + description_id: PropTypes.number, name: PropTypes.string, title: PropTypes.string, }),