diff --git a/frontend/src/DiscoverMovie/Menus/DiscoverMovieSortMenu.js b/frontend/src/DiscoverMovie/Menus/DiscoverMovieSortMenu.js index 95fe93030..5b823c6ff 100644 --- a/frontend/src/DiscoverMovie/Menus/DiscoverMovieSortMenu.js +++ b/frontend/src/DiscoverMovie/Menus/DiscoverMovieSortMenu.js @@ -57,21 +57,21 @@ function DiscoverMovieSortMenu(props) { - {translate('PhysicalRelease')} + {translate('DigitalRelease')} - {translate('DigitalRelease')} + {translate('PhysicalRelease')} + {translate('TmdbRating')} + + + + {translate('ImdbRating')} + + + - {translate('Rating')} + {translate('RottenTomatoesRating')} - - - {label} - - ); -} - -DiscoverMovieOverviewInfoRow.propTypes = { - title: PropTypes.string, - iconName: PropTypes.object.isRequired, - label: PropTypes.oneOfType([PropTypes.string, PropTypes.number]).isRequired -}; - -export default DiscoverMovieOverviewInfoRow; diff --git a/frontend/src/DiscoverMovie/Overview/DiscoverMovieOverviewInfoRow.tsx b/frontend/src/DiscoverMovie/Overview/DiscoverMovieOverviewInfoRow.tsx new file mode 100644 index 000000000..fb1525803 --- /dev/null +++ b/frontend/src/DiscoverMovie/Overview/DiscoverMovieOverviewInfoRow.tsx @@ -0,0 +1,26 @@ +import { IconDefinition } from '@fortawesome/free-regular-svg-icons'; +import React from 'react'; +import Icon from 'Components/Icon'; +import styles from './DiscoverMovieOverviewInfoRow.css'; + +interface DiscoverMovieOverviewInfoRowProps { + title?: string; + iconName?: IconDefinition; + label: string | null; +} + +function DiscoverMovieOverviewInfoRow( + props: DiscoverMovieOverviewInfoRowProps +) { + const { title, iconName, label } = props; + + return ( +
+ + + {label} +
+ ); +} + +export default DiscoverMovieOverviewInfoRow; diff --git a/frontend/src/DiscoverMovie/Overview/DiscoverMovieOverviews.js b/frontend/src/DiscoverMovie/Overview/DiscoverMovieOverviews.js index fe084d134..229d2a4c7 100644 --- a/frontend/src/DiscoverMovie/Overview/DiscoverMovieOverviews.js +++ b/frontend/src/DiscoverMovie/Overview/DiscoverMovieOverviews.js @@ -65,7 +65,8 @@ class DiscoverMovieOverviews extends Component { items, sortKey, overviewOptions, - jumpToCharacter + jumpToCharacter, + isSmallScreen } = this.props; const { @@ -75,13 +76,17 @@ class DiscoverMovieOverviews extends Component { if (prevProps.sortKey !== sortKey || prevProps.overviewOptions !== overviewOptions) { - this.calculateGrid(); + this.calculateGrid(this.state.width, isSmallScreen); } - if (this._grid && + if ( + this._grid && (prevState.width !== width || prevState.rowHeight !== rowHeight || - hasDifferentItemsOrOrder(prevProps.items, items, 'tmdbId'))) { + hasDifferentItemsOrOrder(prevProps.items, items, 'tmdbId') || + prevProps.overviewOptions !== overviewOptions + ) + ) { // recomputeGridSize also forces Grid to discard its cache of rendered cells this._grid.recomputeGridSize(); } diff --git a/frontend/src/DiscoverMovie/Overview/Options/DiscoverMovieOverviewOptionsModalContent.js b/frontend/src/DiscoverMovie/Overview/Options/DiscoverMovieOverviewOptionsModalContent.js index bfe152bce..800c8977b 100644 --- a/frontend/src/DiscoverMovie/Overview/Options/DiscoverMovieOverviewOptionsModalContent.js +++ b/frontend/src/DiscoverMovie/Overview/Options/DiscoverMovieOverviewOptionsModalContent.js @@ -44,11 +44,12 @@ class DiscoverMovieOverviewOptionsModalContent extends Component { this.state = { size: props.size, - showStudio: props.showStudio, - showCertification: props.showCertification, - showRatings: props.showRatings, showYear: props.showYear, + showStudio: props.showStudio, showGenres: props.showGenres, + showTmdbRating: props.showTmdbRating, + showImdbRating: props.showImdbRating, + showCertification: props.showCertification, includeRecommendations: props.includeRecommendations, includeTrending: props.includeTrending, includePopular: props.includePopular @@ -58,11 +59,12 @@ class DiscoverMovieOverviewOptionsModalContent extends Component { componentDidUpdate(prevProps) { const { size, - showStudio, showYear, - showRatings, - showCertification, + showStudio, showGenres, + showTmdbRating, + showImdbRating, + showCertification, includeRecommendations, includeTrending, includePopular @@ -74,24 +76,28 @@ class DiscoverMovieOverviewOptionsModalContent extends Component { state.size = size; } + if (showYear !== prevProps.showYear) { + state.showYear = showYear; + } + if (showStudio !== prevProps.showStudio) { state.showStudio = showStudio; } - if (showYear !== prevProps.showYear) { - state.showYear = showYear; + if (showGenres !== prevProps.showGenres) { + state.showGenres = showGenres; } - if (showRatings !== prevProps.showRatings) { - state.showRatings = showRatings; + if (showTmdbRating !== prevProps.showTmdbRating) { + state.showTmdbRating = showTmdbRating; } - if (showCertification !== prevProps.showCertification) { - state.showCertification = showCertification; + if (showImdbRating !== prevProps.showImdbRating) { + state.showImdbRating = showImdbRating; } - if (showGenres !== prevProps.showGenres) { - state.showGenres = showGenres; + if (showCertification !== prevProps.showCertification) { + state.showCertification = showCertification; } if (includeRecommendations !== prevProps.includeRecommendations) { @@ -142,11 +148,12 @@ class DiscoverMovieOverviewOptionsModalContent extends Component { const { size, - showStudio, - showCertification, - showRatings, showYear, + showStudio, showGenres, + showTmdbRating, + showImdbRating, + showCertification, includeRecommendations, includeTrending, includePopular @@ -209,12 +216,12 @@ class DiscoverMovieOverviewOptionsModalContent extends Component { - {translate('ShowGenres')} + {translate('ShowYear')} @@ -231,23 +238,34 @@ class DiscoverMovieOverviewOptionsModalContent extends Component { - {translate('ShowYear')} + {translate('ShowGenres')} - {translate('ShowRatings')} + {translate('ShowTmdbRating')} + + + + {translate('ShowImdbRating')} + + @@ -279,11 +297,12 @@ class DiscoverMovieOverviewOptionsModalContent extends Component { DiscoverMovieOverviewOptionsModalContent.propTypes = { size: PropTypes.string.isRequired, - showStudio: PropTypes.bool.isRequired, showYear: PropTypes.bool.isRequired, - showRatings: PropTypes.bool.isRequired, - showCertification: PropTypes.bool.isRequired, + showStudio: PropTypes.bool.isRequired, showGenres: PropTypes.bool.isRequired, + showTmdbRating: PropTypes.bool.isRequired, + showImdbRating: PropTypes.bool.isRequired, + showCertification: PropTypes.bool.isRequired, includeRecommendations: PropTypes.bool.isRequired, includeTrending: PropTypes.bool.isRequired, includePopular: PropTypes.bool.isRequired, diff --git a/frontend/src/DiscoverMovie/Posters/DiscoverMoviePoster.js b/frontend/src/DiscoverMovie/Posters/DiscoverMoviePoster.js index 5d372e174..8d45c07e2 100644 --- a/frontend/src/DiscoverMovie/Posters/DiscoverMoviePoster.js +++ b/frontend/src/DiscoverMovie/Posters/DiscoverMoviePoster.js @@ -2,9 +2,12 @@ import PropTypes from 'prop-types'; import React, { Component } from 'react'; import CheckInput from 'Components/Form/CheckInput'; import Icon from 'Components/Icon'; +import ImdbRating from 'Components/ImdbRating'; import Label from 'Components/Label'; import IconButton from 'Components/Link/IconButton'; import Link from 'Components/Link/Link'; +import RottenTomatoRating from 'Components/RottenTomatoRating'; +import TmdbRating from 'Components/TmdbRating'; import Popover from 'Components/Tooltip/Popover'; import AddNewDiscoverMovieModal from 'DiscoverMovie/AddNewDiscoverMovieModal'; import ExcludeMovieModal from 'DiscoverMovie/Exclusion/ExcludeMovieModal'; @@ -86,6 +89,10 @@ class DiscoverMoviePoster extends Component { posterWidth, posterHeight, showTitle, + showTmdbRating, + showImdbRating, + showRottenTomatoesRating, + ratings, isExisting, isExcluded, isSelected, @@ -192,18 +199,39 @@ class DiscoverMoviePoster extends Component { - { - showTitle && -
- {title} -
- } + {showTitle ? +
+ {title} +
: + null} + + {showTmdbRating && !!ratings.tmdb ? ( +
+ +
+ ) : null} + + {showImdbRating && !!ratings.imdb ? ( +
+ +
+ ) : null} + + {showRottenTomatoesRating && !!ratings.rottenTomatoes ? ( +
+ +
+ ) : null} @@ -243,6 +271,10 @@ DiscoverMoviePoster.propTypes = { posterWidth: PropTypes.number.isRequired, posterHeight: PropTypes.number.isRequired, showTitle: PropTypes.bool.isRequired, + showTmdbRating: PropTypes.bool.isRequired, + showImdbRating: PropTypes.bool.isRequired, + showRottenTomatoesRating: PropTypes.bool.isRequired, + ratings: PropTypes.object.isRequired, showRelativeDates: PropTypes.bool.isRequired, shortDateFormat: PropTypes.string.isRequired, timeFormat: PropTypes.string.isRequired, diff --git a/frontend/src/DiscoverMovie/Posters/DiscoverMoviePosterInfo.js b/frontend/src/DiscoverMovie/Posters/DiscoverMoviePosterInfo.js index 2fce4c1ff..aba00c799 100644 --- a/frontend/src/DiscoverMovie/Posters/DiscoverMoviePosterInfo.js +++ b/frontend/src/DiscoverMovie/Posters/DiscoverMoviePosterInfo.js @@ -1,6 +1,8 @@ import PropTypes from 'prop-types'; import React from 'react'; import Icon from 'Components/Icon'; +import ImdbRating from 'Components/ImdbRating'; +import RottenTomatoRating from 'Components/RottenTomatoRating'; import TmdbRating from 'Components/TmdbRating'; import { icons } from 'Helpers/Props'; import getMovieStatusDetails from 'Movie/getMovieStatusDetails'; @@ -23,7 +25,10 @@ function DiscoverMoviePosterInfo(props) { showRelativeDates, shortDateFormat, timeFormat, - movieRuntimeFormat + movieRuntimeFormat, + showTmdbRating, + showImdbRating, + showRottenTomatoesRating } = props; if (sortKey === 'status' && status) { @@ -112,10 +117,26 @@ function DiscoverMoviePosterInfo(props) { ); } - if (sortKey === 'ratings' && ratings) { + if (!showTmdbRating && sortKey === 'tmdbRating' && !!ratings.tmdb) { return (
- + +
+ ); + } + + if (!showImdbRating && sortKey === 'imdbRating' && !!ratings.imdb) { + return ( +
+ +
+ ); + } + + if (!showRottenTomatoesRating && sortKey === 'rottenTomatoesRating' && !!ratings.rottenTomatoes) { + return ( +
+
); } @@ -136,7 +157,10 @@ DiscoverMoviePosterInfo.propTypes = { showRelativeDates: PropTypes.bool.isRequired, shortDateFormat: PropTypes.string.isRequired, timeFormat: PropTypes.string.isRequired, - movieRuntimeFormat: PropTypes.string.isRequired + movieRuntimeFormat: PropTypes.string.isRequired, + showTmdbRating: PropTypes.bool.isRequired, + showImdbRating: PropTypes.bool.isRequired, + showRottenTomatoesRating: PropTypes.bool.isRequired }; export default DiscoverMoviePosterInfo; diff --git a/frontend/src/DiscoverMovie/Posters/DiscoverMoviePosters.js b/frontend/src/DiscoverMovie/Posters/DiscoverMoviePosters.js index 50d4f42b3..ae3cccb0f 100644 --- a/frontend/src/DiscoverMovie/Posters/DiscoverMoviePosters.js +++ b/frontend/src/DiscoverMovie/Posters/DiscoverMoviePosters.js @@ -36,15 +36,15 @@ function calculateColumnWidth(width, posterSize, isSmallScreen) { function calculateRowHeight(posterHeight, sortKey, isSmallScreen, posterOptions) { const { detailedProgressBar, - showTitle + showTitle, + showTmdbRating, + showImdbRating, + showRottenTomatoesRating } = posterOptions; - const nextAiringHeight = 19; - const heights = [ posterHeight, detailedProgressBar ? detailedProgressBarHeight : progressBarHeight, - nextAiringHeight, isSmallScreen ? columnPaddingSmallScreen : columnPadding ]; @@ -52,8 +52,42 @@ function calculateRowHeight(posterHeight, sortKey, isSmallScreen, posterOptions) heights.push(19); } + if (showTmdbRating) { + heights.push(19); + } + + if (showImdbRating) { + heights.push(19); + } + + if (showRottenTomatoesRating) { + heights.push(19); + } + switch (sortKey) { case 'studio': + case 'inCinemas': + case 'digitalRelease': + case 'physicalRelease': + case 'runtime': + case 'certification': + heights.push(19); + break; + case 'tmdbRating': + if (!showTmdbRating) { + heights.push(19); + } + break; + case 'imdbRating': + if (!showImdbRating) { + heights.push(19); + } + break; + case 'rottenTomatoesRating': + if (!showRottenTomatoesRating) { + heights.push(19); + } + break; default: // No need to add a height of 0 } @@ -182,7 +216,10 @@ class DiscoverMoviePosters extends Component { } = this.state; const { - showTitle + showTitle, + showTmdbRating, + showImdbRating, + showRottenTomatoesRating } = posterOptions; const movieIdx = rowIndex * columnCount + columnIndex; @@ -208,6 +245,9 @@ class DiscoverMoviePosters extends Component { posterWidth={posterWidth} posterHeight={posterHeight} showTitle={showTitle} + showTmdbRating={showTmdbRating} + showImdbRating={showImdbRating} + showRottenTomatoesRating={showRottenTomatoesRating} showRelativeDates={showRelativeDates} shortDateFormat={shortDateFormat} timeFormat={timeFormat} diff --git a/frontend/src/DiscoverMovie/Posters/Options/DiscoverMoviePosterOptionsModalContent.js b/frontend/src/DiscoverMovie/Posters/Options/DiscoverMoviePosterOptionsModalContent.js index 4d2743215..93eb68a6f 100644 --- a/frontend/src/DiscoverMovie/Posters/Options/DiscoverMoviePosterOptionsModalContent.js +++ b/frontend/src/DiscoverMovie/Posters/Options/DiscoverMoviePosterOptionsModalContent.js @@ -45,6 +45,9 @@ class DiscoverMoviePosterOptionsModalContent extends Component { this.state = { size: props.size, showTitle: props.showTitle, + showTmdbRating: props.showTmdbRating, + showImdbRating: props.showImdbRating, + showRottenTomatoesRating: props.showRottenTomatoesRating, includeRecommendations: props.includeRecommendations, includeTrending: props.includeTrending, includePopular: props.includePopular @@ -55,6 +58,9 @@ class DiscoverMoviePosterOptionsModalContent extends Component { const { size, showTitle, + showTmdbRating, + showImdbRating, + showRottenTomatoesRating, includeRecommendations, includeTrending, includePopular @@ -70,6 +76,18 @@ class DiscoverMoviePosterOptionsModalContent extends Component { state.showTitle = showTitle; } + if (showTmdbRating !== prevProps.showTmdbRating) { + state.showTmdbRating = showTmdbRating; + } + + if (showImdbRating !== prevProps.showImdbRating) { + state.showImdbRating = showImdbRating; + } + + if (showRottenTomatoesRating !== prevProps.showRottenTomatoesRating) { + state.showRottenTomatoesRating = showRottenTomatoesRating; + } + if (includeRecommendations !== prevProps.includeRecommendations) { state.includeRecommendations = includeRecommendations; } @@ -119,6 +137,9 @@ class DiscoverMoviePosterOptionsModalContent extends Component { const { size, showTitle, + showTmdbRating, + showImdbRating, + showRottenTomatoesRating, includeRecommendations, includeTrending, includePopular @@ -191,6 +212,42 @@ class DiscoverMoviePosterOptionsModalContent extends Component { onChange={this.onChangePosterOption} /> + + + {translate('ShowTmdbRating')} + + + + + + {translate('ShowImdbRating')} + + + + + + {translate('ShowRottenTomatoesRating')} + + + @@ -209,6 +266,9 @@ class DiscoverMoviePosterOptionsModalContent extends Component { DiscoverMoviePosterOptionsModalContent.propTypes = { size: PropTypes.string.isRequired, showTitle: PropTypes.bool.isRequired, + showTmdbRating: PropTypes.bool.isRequired, + showImdbRating: PropTypes.bool.isRequired, + showRottenTomatoesRating: PropTypes.bool.isRequired, includeRecommendations: PropTypes.bool.isRequired, includeTrending: PropTypes.bool.isRequired, includePopular: PropTypes.bool.isRequired, diff --git a/frontend/src/DiscoverMovie/Table/DiscoverMovieHeader.css b/frontend/src/DiscoverMovie/Table/DiscoverMovieHeader.css index 3afdebe47..5b6328392 100644 --- a/frontend/src/DiscoverMovie/Table/DiscoverMovieHeader.css +++ b/frontend/src/DiscoverMovie/Table/DiscoverMovieHeader.css @@ -32,7 +32,9 @@ flex: 1 0 125px; } -.ratings, +.tmdbRating, +.imdbRating, +.rottenTomatoesRating, .runtime { composes: headerCell from '~Components/Table/VirtualTableHeaderCell.css'; diff --git a/frontend/src/DiscoverMovie/Table/DiscoverMovieHeader.css.d.ts b/frontend/src/DiscoverMovie/Table/DiscoverMovieHeader.css.d.ts index 254a1cfb5..3f525862d 100644 --- a/frontend/src/DiscoverMovie/Table/DiscoverMovieHeader.css.d.ts +++ b/frontend/src/DiscoverMovie/Table/DiscoverMovieHeader.css.d.ts @@ -6,6 +6,7 @@ interface CssExports { 'collection': string; 'digitalRelease': string; 'genres': string; + 'imdbRating': string; 'inCinemas': string; 'isPopular': string; 'isRecommendation': string; @@ -14,11 +15,12 @@ interface CssExports { 'originalLanguage': string; 'physicalRelease': string; 'popularity': string; - 'ratings': string; + 'rottenTomatoesRating': string; 'runtime': string; 'sortTitle': string; 'status': string; 'studio': string; + 'tmdbRating': string; } export const cssExports: CssExports; export default cssExports; diff --git a/frontend/src/DiscoverMovie/Table/DiscoverMovieRow.css b/frontend/src/DiscoverMovie/Table/DiscoverMovieRow.css index f41b5e4cc..b93d41b67 100644 --- a/frontend/src/DiscoverMovie/Table/DiscoverMovieRow.css +++ b/frontend/src/DiscoverMovie/Table/DiscoverMovieRow.css @@ -57,7 +57,9 @@ flex: 1 0 125px; } -.ratings, +.tmdbRating, +.imdbRating, +.rottenTomatoesRating, .runtime { composes: cell; diff --git a/frontend/src/DiscoverMovie/Table/DiscoverMovieRow.css.d.ts b/frontend/src/DiscoverMovie/Table/DiscoverMovieRow.css.d.ts index 7ecc09ced..c0e7b1be7 100644 --- a/frontend/src/DiscoverMovie/Table/DiscoverMovieRow.css.d.ts +++ b/frontend/src/DiscoverMovie/Table/DiscoverMovieRow.css.d.ts @@ -11,6 +11,7 @@ interface CssExports { 'exclusionIcon': string; 'externalLinks': string; 'genres': string; + 'imdbRating': string; 'inCinemas': string; 'isPopular': string; 'isRecommendation': string; @@ -19,12 +20,13 @@ interface CssExports { 'originalLanguage': string; 'physicalRelease': string; 'popularity': string; - 'ratings': string; + 'rottenTomatoesRating': string; 'runtime': string; 'sortTitle': string; 'status': string; 'statusIcon': string; 'studio': string; + 'tmdbRating': string; } export const cssExports: CssExports; export default cssExports; diff --git a/frontend/src/DiscoverMovie/Table/DiscoverMovieRow.js b/frontend/src/DiscoverMovie/Table/DiscoverMovieRow.js index 6541ec238..9db54e7a6 100644 --- a/frontend/src/DiscoverMovie/Table/DiscoverMovieRow.js +++ b/frontend/src/DiscoverMovie/Table/DiscoverMovieRow.js @@ -1,9 +1,11 @@ import PropTypes from 'prop-types'; import React, { Component } from 'react'; import Icon from 'Components/Icon'; +import ImdbRating from 'Components/ImdbRating'; import ImportListListConnector from 'Components/ImportListListConnector'; import IconButton from 'Components/Link/IconButton'; import Link from 'Components/Link/Link'; +import RottenTomatoRating from 'Components/RottenTomatoRating'; import RelativeDateCellConnector from 'Components/Table/Cells/RelativeDateCellConnector'; import VirtualTableRowCell from 'Components/Table/Cells/VirtualTableRowCell'; import VirtualTableSelectCell from 'Components/Table/Cells/VirtualTableSelectCell'; @@ -253,15 +255,35 @@ class DiscoverMovieRow extends Component { ); } - if (name === 'ratings') { + if (name === 'tmdbRating') { return ( - + {ratings.tmdb ? : null} + + ); + } + + if (name === 'imdbRating') { + return ( + + {ratings.imdb ? : null} + + ); + } + + if (name === 'rottenTomatoesRating') { + return ( + + {ratings.rottenTomatoes ? : null} ); } diff --git a/frontend/src/Helpers/Props/icons.js b/frontend/src/Helpers/Props/icons.js index de79dc406..0acf73613 100644 --- a/frontend/src/Helpers/Props/icons.js +++ b/frontend/src/Helpers/Props/icons.js @@ -1,6 +1,10 @@ // +// Brands +import { + faImdb as fabImdb +} from '@fortawesome/free-brands-svg-icons'; +// // Regular - import { faBookmark as farBookmark, faCalendar as farCalendar, @@ -175,6 +179,7 @@ export const HEART = fasHeart; export const HISTORY = fasHistory; export const HOUSEKEEPING = fasHome; export const IGNORE = fasTimesCircle; +export const IMDB = fabImdb; export const IN_CINEMAS = fasTicketAlt; export const INFO = fasInfoCircle; export const INTERACTIVE = fasUser; diff --git a/frontend/src/Store/Actions/discoverMovieActions.js b/frontend/src/Store/Actions/discoverMovieActions.js index 295af8d25..bd4725c46 100644 --- a/frontend/src/Store/Actions/discoverMovieActions.js +++ b/frontend/src/Store/Actions/discoverMovieActions.js @@ -58,17 +58,20 @@ export const defaultState = { posterOptions: { size: 'large', - showTitle: false + showTitle: false, + showTmdbRating: false, + showImdbRating: false, + showRottenTomatoesRating: false }, overviewOptions: { - detailedProgressBar: false, size: 'medium', - showStudio: true, - showRatings: true, showYear: true, - showCertification: true, - showGenres: true + showStudio: true, + showGenres: true, + showTmdbRating: false, + showImdbRating: false, + showCertification: true }, tableOptions: { @@ -136,14 +139,14 @@ export const defaultState = { isVisible: true }, { - name: 'physicalRelease', - label: () => translate('PhysicalRelease'), + name: 'digitalRelease', + label: () => translate('DigitalRelease'), isSortable: true, isVisible: false }, { - name: 'digitalRelease', - label: () => translate('DigitalRelease'), + name: 'physicalRelease', + label: () => translate('PhysicalRelease'), isSortable: true, isVisible: false }, @@ -160,8 +163,20 @@ export const defaultState = { isVisible: false }, { - name: 'ratings', - label: () => translate('Ratings'), + name: 'tmdbRating', + label: () => translate('TmdbRating'), + isSortable: true, + isVisible: false + }, + { + name: 'imdbRating', + label: () => translate('ImdbRating'), + isSortable: true, + isVisible: false + }, + { + name: 'rottenTomatoesRating', + label: () => translate('RottenTomatoesRating'), isSortable: true, isVisible: false }, @@ -232,12 +247,6 @@ export const defaultState = { return studio ? studio.toLowerCase() : ''; }, - ratings: function(item) { - const { ratings = {} } = item; - - return ratings.tmdb? ratings.tmdb.value : 0; - }, - inCinemas: function(item, direction) { if (item.inCinemas) { return moment(item.inCinemas).unix(); @@ -272,6 +281,18 @@ export const defaultState = { } return Number.MAX_VALUE; + }, + + tmdbRating: function({ ratings = {} }) { + return ratings.tmdb ? ratings.tmdb.value : 0; + }, + + imdbRating: function({ ratings = {} }) { + return ratings.imdb ? ratings.imdb.value : 0; + }, + + rottenTomatoesRating: function({ ratings = {} }) { + return ratings.rottenTomatoes ? ratings.rottenTomatoes.value : -1; } }, diff --git a/package.json b/package.json index f9b7a9913..3663a44dc 100644 --- a/package.json +++ b/package.json @@ -24,6 +24,7 @@ "dependencies": { "@fortawesome/fontawesome-free": "6.4.0", "@fortawesome/fontawesome-svg-core": "6.4.0", + "@fortawesome/free-brands-svg-icons": "6.6.0", "@fortawesome/free-regular-svg-icons": "6.4.0", "@fortawesome/free-solid-svg-icons": "6.4.0", "@fortawesome/react-fontawesome": "0.2.0", diff --git a/src/NzbDrone.Core/Localization/Core/en.json b/src/NzbDrone.Core/Localization/Core/en.json index a80674566..e0af37ac9 100644 --- a/src/NzbDrone.Core/Localization/Core/en.json +++ b/src/NzbDrone.Core/Localization/Core/en.json @@ -244,6 +244,7 @@ "CountDownloadClientsSelected": "{count} download client(s) selected", "CountImportListsSelected": "{count} import list(s) selected", "CountIndexersSelected": "{count} indexer(s) selected", + "CountVotes": "{votes} votes", "CreateEmptyMovieFolders": "Create empty movie folders", "CreateEmptyMovieFoldersHelpText": "Create missing movie folders during disk scan", "CreateGroup": "Create group", diff --git a/yarn.lock b/yarn.lock index a563dd17c..c2cda529d 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1111,6 +1111,11 @@ resolved "https://registry.yarnpkg.com/@fortawesome/fontawesome-common-types/-/fontawesome-common-types-6.4.0.tgz#88da2b70d6ca18aaa6ed3687832e11f39e80624b" integrity sha512-HNii132xfomg5QVZw0HwXXpN22s7VBHQBv9CeOu9tfJnhsWQNd2lmTNi8CSrnw5B+5YOmzu1UoPAyxaXsJ6RgQ== +"@fortawesome/fontawesome-common-types@6.6.0": + version "6.6.0" + resolved "https://registry.yarnpkg.com/@fortawesome/fontawesome-common-types/-/fontawesome-common-types-6.6.0.tgz#31ab07ca6a06358c5de4d295d4711b675006163f" + integrity sha512-xyX0X9mc0kyz9plIyryrRbl7ngsA9jz77mCZJsUkLl+ZKs0KWObgaEBoSgQiYWAsSmjz/yjl0F++Got0Mdp4Rw== + "@fortawesome/fontawesome-free@6.4.0": version "6.4.0" resolved "https://registry.yarnpkg.com/@fortawesome/fontawesome-free/-/fontawesome-free-6.4.0.tgz#1ee0c174e472c84b23cb46c995154dc383e3b4fe" @@ -1123,6 +1128,13 @@ dependencies: "@fortawesome/fontawesome-common-types" "6.4.0" +"@fortawesome/free-brands-svg-icons@6.6.0": + version "6.6.0" + resolved "https://registry.yarnpkg.com/@fortawesome/free-brands-svg-icons/-/free-brands-svg-icons-6.6.0.tgz#2797f2cc66d21e7e47fa64e680b8835e8d30e825" + integrity sha512-1MPD8lMNW/earme4OQi1IFHtmHUwAKgghXlNwWi9GO7QkTfD+IIaYpIai4m2YJEzqfEji3jFHX1DZI5pbY/biQ== + dependencies: + "@fortawesome/fontawesome-common-types" "6.6.0" + "@fortawesome/free-regular-svg-icons@6.4.0": version "6.4.0" resolved "https://registry.yarnpkg.com/@fortawesome/free-regular-svg-icons/-/free-regular-svg-icons-6.4.0.tgz#cacc53bd8d832d46feead412d9ea9ce80a55e13a"