Lidarr/frontend/src/Artist/Index/ProgressBar/ArtistIndexProgressBar.js

49 lines
1.5 KiB
JavaScript
Raw Normal View History

2017-09-04 02:20:56 +00:00
import PropTypes from 'prop-types';
import React from 'react';
import ProgressBar from 'Components/ProgressBar';
2020-09-07 01:33:10 +00:00
import { sizes } from 'Helpers/Props';
import getProgressBarKind from 'Utilities/Artist/getProgressBarKind';
2021-10-03 15:01:09 +00:00
import translate from 'Utilities/String/translate';
import styles from './ArtistIndexProgressBar.css';
2017-09-04 02:20:56 +00:00
function ArtistIndexProgressBar(props) {
2017-09-04 02:20:56 +00:00
const {
monitored,
status,
trackCount,
trackFileCount,
2018-03-15 01:28:46 +00:00
totalTrackCount,
2017-09-04 02:20:56 +00:00
posterWidth,
detailedProgressBar
} = props;
const progress = trackCount ? trackFileCount / trackCount * 100 : 100;
const text = `${trackFileCount} / ${trackCount}`;
return (
<ProgressBar
className={styles.progressBar}
containerClassName={styles.progress}
progress={progress}
kind={getProgressBarKind(status, monitored, progress)}
size={detailedProgressBar ? sizes.MEDIUM : sizes.SMALL}
showText={detailedProgressBar}
text={text}
2021-10-03 15:01:09 +00:00
title={translate('TrackFileCountTrackCountTotalTotalTrackCountInterp', [trackFileCount, trackCount, totalTrackCount])}
2017-09-04 02:20:56 +00:00
width={posterWidth}
/>
);
}
ArtistIndexProgressBar.propTypes = {
2017-09-04 02:20:56 +00:00
monitored: PropTypes.bool.isRequired,
status: PropTypes.string.isRequired,
trackCount: PropTypes.number.isRequired,
trackFileCount: PropTypes.number.isRequired,
2018-03-15 01:28:46 +00:00
totalTrackCount: PropTypes.number.isRequired,
2017-09-04 02:20:56 +00:00
posterWidth: PropTypes.number.isRequired,
detailedProgressBar: PropTypes.bool.isRequired
};
export default ArtistIndexProgressBar;