]> git.localhorst.tv Git - alttp.git/blobdiff - resources/js/components/episodes/Item.js
sync episode channels
[alttp.git] / resources / js / components / episodes / Item.js
index 8f1bafcb240508500e0336768c3a4af99d70b4ef..3a3afa44f8c548b38ba02ebe97d5045a22c65ce7 100644 (file)
@@ -1,34 +1,70 @@
+import moment from 'moment';
 import PropTypes from 'prop-types';
 import React from 'react';
 import { useTranslation } from 'react-i18next';
 
+import Channels from './Channels';
 import Players from './Players';
 
+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 { t } = useTranslation();
 
-       return <div className="episodes-item d-flex align-items-start my-3 p-2 border rounded">
+       const classNames = [
+               'episodes-item',
+               'd-flex',
+               'align-items-start',
+               'my-3',
+               'p-2',
+               'border',
+               'rounded',
+       ];
+       if (isActive(episode)) {
+               classNames.push('is-active');
+       }
+
+       return <div className={classNames.join(' ')}>
                <div className="episode-start me-3 fs-4 text-end">
                        {t('schedule.startTime', { date: new Date(episode.start) })}
                </div>
                <div className="flex-fill">
-                       {episode.title ?
-                               <div className="episode-title fs-4">
-                                       {episode.title}
+                       <div className="d-flex align-items-start justify-content-between">
+                               <div>
+                                       {episode.title ?
+                                               <div className="episode-title fs-4">
+                                                       {episode.title}
+                                               </div>
+                                       : null}
+                                       {episode.event ?
+                                               <div className="episode-event">
+                                                       {episode.event.title}
+                                               </div>
+                                       : null}
                                </div>
-                       : null}
-                       {episode.event ?
-                               <div className="episode-event">
-                                       {episode.event.title}
+                               <div>
+                                       {episode.channels ?
+                                               <Channels channels={episode.channels} />
+                                       : null}
                                </div>
+                       </div>
+                       {episode.players ?
+                               <Players players={episode.players} />
                        : null}
-                       <Players players={episode.players} />
                </div>
        </div>;
 };
 
 Item.propTypes = {
        episode: PropTypes.shape({
+               channels: PropTypes.arrayOf(PropTypes.shape({
+               })),
                event: PropTypes.shape({
                        title: PropTypes.string,
                }),