]> git.localhorst.tv Git - alttp.git/blobdiff - resources/js/components/episodes/Item.js
small ux improvements
[alttp.git] / resources / js / components / episodes / Item.js
index 2078c6dc6573bb74f554032ae67a3fdc0323cd3d..19760ee6c5624cb859cb5b65438558f067a56761 100644 (file)
@@ -1,21 +1,26 @@
 import moment from 'moment';
 import PropTypes from 'prop-types';
 import React from 'react';
+import { Button } from 'react-bootstrap';
 import { useTranslation } from 'react-i18next';
 
 import Channels from './Channels';
 import Crew from './Crew';
+import MultiLink from './MultiLink';
 import Players from './Players';
+import Icon from '../common/Icon';
+import { 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');
+       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 }) => {
+const Item = ({ episode, onAddRestream, onEditRestream, user }) => {
        const { t } = useTranslation();
 
        const classNames = [
@@ -31,7 +36,19 @@ const Item = ({ episode }) => {
                classNames.push('is-active');
        }
 
-       return <div className={classNames.join(' ')}>
+       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="episode-start me-3 fs-4 text-end">
                        {t('schedule.startTime', { date: new Date(episode.start) })}
                </div>
@@ -49,13 +66,31 @@ const Item = ({ episode }) => {
                                                </div>
                                        : null}
                                </div>
-                               <div>
-                                       {episode.channels ?
-                                               <Channels channels={episode.channels} />
+                               <div className="episode-channel-links text-end">
+                                       {hasChannels ?
+                                               <Channels
+                                                       channels={episode.channels}
+                                                       episode={episode}
+                                                       onEditRestream={onEditRestream}
+                                               />
+                                       : null}
+                                       {!hasChannels && hasPlayers ?
+                                               <MultiLink players={episode.players} />
+                                       : null}
+                                       {onAddRestream && canRestreamEpisode(user, episode) ?
+                                               <div>
+                                                       <Button
+                                                               onClick={() => onAddRestream(episode)}
+                                                               title={t('episodes.addRestream')}
+                                                               variant="outline-secondary"
+                                                       >
+                                                               <Icon.ADD title="" />
+                                                       </Button>
+                                               </div>
                                        : null}
                                </div>
                        </div>
-                       {episode.players && episode.players.length ?
+                       {hasPlayers ?
                                <Players players={episode.players} />
                        : null}
                        {episode.crew && episode.crew.length ?
@@ -72,6 +107,7 @@ Item.propTypes = {
                crew: PropTypes.arrayOf(PropTypes.shape({
                })),
                event: PropTypes.shape({
+                       corner: PropTypes.string,
                        title: PropTypes.string,
                }),
                players: PropTypes.arrayOf(PropTypes.shape({
@@ -79,6 +115,10 @@ Item.propTypes = {
                start: PropTypes.string,
                title: PropTypes.string,
        }),
+       onAddRestream: PropTypes.func,
+       onEditRestream: PropTypes.func,
+       user: PropTypes.shape({
+       }),
 };
 
-export default Item;
+export default withUser(Item);