From 4fafdcabb7b69c689b94840a8ada690550ab7553 Mon Sep 17 00:00:00 2001 From: nitsua Date: Fri, 11 Sep 2020 13:00:14 -0400 Subject: [PATCH] Fix: Addressed issue with status color not showing on Movie > Details (only purple was working) --- .../src/Movie/Details/MovieStatusLabel.css | 2 +- .../src/Movie/Details/MovieStatusLabel.js | 17 +++++++---- .../ProgressBar/MovieIndexProgressBar.js | 2 +- frontend/src/Movie/MovieFileStatus.js | 4 +-- .../src/Utilities/Movie/getQueueStatusText.js | 29 ++++++------------- .../src/Utilities/String/firstCharToUpper.js | 9 ++++++ 6 files changed, 33 insertions(+), 30 deletions(-) create mode 100644 frontend/src/Utilities/String/firstCharToUpper.js diff --git a/frontend/src/Movie/Details/MovieStatusLabel.css b/frontend/src/Movie/Details/MovieStatusLabel.css index 04470753b..fff54bd98 100644 --- a/frontend/src/Movie/Details/MovieStatusLabel.css +++ b/frontend/src/Movie/Details/MovieStatusLabel.css @@ -8,7 +8,7 @@ border-left: 4px solid $successColor; } -.unreleased { +.notAvailable { padding-left: 2px; border-left: 4px solid $primaryColor; } diff --git a/frontend/src/Movie/Details/MovieStatusLabel.js b/frontend/src/Movie/Details/MovieStatusLabel.js index cbb03826c..c605bb91d 100644 --- a/frontend/src/Movie/Details/MovieStatusLabel.js +++ b/frontend/src/Movie/Details/MovieStatusLabel.js @@ -1,6 +1,7 @@ import PropTypes from 'prop-types'; import React from 'react'; import getQueueStatusText from 'Utilities/Movie/getQueueStatusText'; +import firstCharToUpper from 'Utilities/String/firstCharToUpper'; import translate from 'Utilities/String/translate'; import styles from './MovieStatusLabel.css'; @@ -10,22 +11,25 @@ function getMovieStatus(hasFile, isMonitored, isAvailable, queueDetails = false) const queueStatus = queueDetails.items[0].status; const queueState = queueDetails.items[0].trackedDownloadStatus; const queueStatusText = getQueueStatusText(queueStatus, queueState); - return queueStatusText.longText; + + if (queueStatusText) { + return queueStatusText; + } } if (hasFile) { - return translate('Downloaded'); + return 'downloaded'; } if (!isMonitored) { - return translate('Unmonitored'); + return 'unmonitored'; } if (isAvailable && !hasFile) { - return translate('Missing'); + return 'missing'; } - return translate('NotAvailable'); + return 'notAvailable'; } function MovieStatusLabel(props) { @@ -38,6 +42,7 @@ function MovieStatusLabel(props) { const status = getMovieStatus(hasMovieFiles, monitored, isAvailable, queueDetails); let statusClass = status; + if (queueDetails.items.length) { statusClass = 'queue'; } @@ -46,7 +51,7 @@ function MovieStatusLabel(props) { - {status} + {translate(firstCharToUpper(status))} ); } diff --git a/frontend/src/Movie/Index/ProgressBar/MovieIndexProgressBar.js b/frontend/src/Movie/Index/ProgressBar/MovieIndexProgressBar.js index 8bbcda882..3d7aad8ec 100644 --- a/frontend/src/Movie/Index/ProgressBar/MovieIndexProgressBar.js +++ b/frontend/src/Movie/Index/ProgressBar/MovieIndexProgressBar.js @@ -46,7 +46,7 @@ function MovieIndexProgressBar(props) { size={detailedProgressBar ? sizes.MEDIUM : sizes.SMALL} showText={detailedProgressBar} width={posterWidth} - text={(queueStatusText) ? queueStatusText.shortText : translate(movieStatus)} + text={(queueStatusText) ? queueStatusText : translate(movieStatus)} /> ); } diff --git a/frontend/src/Movie/MovieFileStatus.js b/frontend/src/Movie/MovieFileStatus.js index c66f8584a..7c6be4825 100644 --- a/frontend/src/Movie/MovieFileStatus.js +++ b/frontend/src/Movie/MovieFileStatus.js @@ -25,10 +25,10 @@ function MovieFileStatus(props) { return (
); diff --git a/frontend/src/Utilities/Movie/getQueueStatusText.js b/frontend/src/Utilities/Movie/getQueueStatusText.js index 768515d4a..d99bde234 100644 --- a/frontend/src/Utilities/Movie/getQueueStatusText.js +++ b/frontend/src/Utilities/Movie/getQueueStatusText.js @@ -6,8 +6,7 @@ export default function getQueueStatusText(queueStatus, queueState) { return; } - let statusLong = translate('Downloading'); - let statusShort = translate('Downloading'); + let status = translate('Downloading'); switch (true) { case queueStatus !== 'completed': @@ -15,21 +14,15 @@ export default function getQueueStatusText(queueStatus, queueState) { case 'queue': case 'paused': case 'failed': - statusLong = `${translate('Downloading')}: ${translate(titleCase(queueStatus))}`; - statusShort = titleCase(queueStatus); + case 'downloading': + status = titleCase(queueStatus); break; case 'delay': - statusLong = `${translate('Downloading')}: ${translate('Pending')}`; - statusShort = translate('Pending'); + status = translate('Pending'); break; case 'DownloadClientUnavailable': case 'warning': - statusLong = `${translate('Downloading')}: ${translate('Error')}`; - statusShort = translate('Error'); - break; - case 'downloading': - statusLong = titleCase(queueStatus); - statusShort = titleCase(queueStatus); + status = translate('Error'); break; default: } @@ -38,16 +31,13 @@ export default function getQueueStatusText(queueStatus, queueState) { case queueStatus === 'completed': switch (queueState) { case 'importPending': - statusLong = `${translate('Downloaded')}: ${translate('Pending')}`; - statusShort = translate('Downloaded'); + status = translate('Pending'); break; case 'importing': - statusLong = `${translate('Downloaded')}: ${translate('Importing')}`; - statusShort = translate('Downloaded'); + status = translate('Importing'); break; case 'failedPending': - statusLong = `${translate('Downloaded')}: ${translate('Waiting')}`; - statusShort = translate('Downloaded'); + status = translate('Waiting'); break; default: } @@ -56,6 +46,5 @@ export default function getQueueStatusText(queueStatus, queueState) { default: } - const result = { longText: statusLong, shortText: statusShort }; - return result; + return status; } diff --git a/frontend/src/Utilities/String/firstCharToUpper.js b/frontend/src/Utilities/String/firstCharToUpper.js new file mode 100644 index 000000000..1ce64831c --- /dev/null +++ b/frontend/src/Utilities/String/firstCharToUpper.js @@ -0,0 +1,9 @@ +function firstCharToUpper(input) { + if (!input) { + return ''; + } + + return [].map.call(input, (char, i) => (i ? char : char.toUpperCase())).join(''); +} + +export default firstCharToUpper;