X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=resources%2Fjs%2Fcomponents%2Fepisodes%2FItem.js;h=d68df8ece8cb62b5a7aec0da2e61d1db7b6f08f8;hb=1e725fef6dc440aaeea8c30e1e0598dc5d24ad86;hp=8f1bafcb240508500e0336768c3a4af99d70b4ef;hpb=dec43db11e9433f5bfcfaa091518082559cb3169;p=alttp.git diff --git a/resources/js/components/episodes/Item.js b/resources/js/components/episodes/Item.js index 8f1bafc..d68df8e 100644 --- a/resources/js/components/episodes/Item.js +++ b/resources/js/components/episodes/Item.js @@ -1,42 +1,152 @@ 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 { getLink } from '../../helpers/Event'; +import { canApplyForEpisode, canRestreamEpisode } from '../../helpers/permissions'; +import { withUser } from '../../helpers/UserContext'; -const Item = ({ episode }) => { +const Item = ({ episode, onAddRestream, onApply, onEditRestream, user }) => { const { t } = useTranslation(); - return
-
- {t('schedule.startTime', { date: new Date(episode.start) })} + const classNames = [ + 'episodes-item', + 'my-3', + 'p-2', + 'border', + 'rounded', + ]; + if (isActive(episode)) { + 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
+
+
+ {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} + {episode.raceroom ? +
+ +
+ : null} + {onAddRestream && canRestreamEpisode(user, episode) ? +
+ +
+ : null} +
-
- {episode.title ? -
- {episode.title} +
+ {hasPlayers ? + + : null} + {(episode.crew && episode.crew.length) || (!hasPassed(episode) && ( + hasSGRestream(episode) + || canApplyForEpisode(user, episode, 'commentary') + || canApplyForEpisode(user, episode, 'tracking') + )) ? +
+
: null} {episode.event ? -
- {episode.event.title} +
+ {episode.event.description_id ? + + {episode.event.title} + + : + episode.event.title + }
: null} -
; }; 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({ })), + raceroom: PropTypes.string, 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);