import PropTypes from 'prop-types'; import React, { Component } from 'react'; import { icons, kinds, sizes } from 'Helpers/Props'; import Button from 'Components/Link/Button'; import FieldSet from 'Components/FieldSet'; import Icon from 'Components/Icon'; import LoadingIndicator from 'Components/Loading/LoadingIndicator'; import FileBrowserModal from 'Components/FileBrowser/FileBrowserModal'; import PageContent from 'Components/Page/PageContent'; import PageContentBodyConnector from 'Components/Page/PageContentBodyConnector'; import Table from 'Components/Table/Table'; import TableBody from 'Components/Table/TableBody'; import ImportArtistRootFolderRowConnector from './ImportArtistRootFolderRowConnector'; import styles from './ImportArtistSelectFolder.css'; const rootFolderColumns = [ { name: 'path', label: 'Path', isVisible: true }, { name: 'freeSpace', label: 'Free Space', isVisible: true }, { name: 'unmappedFolders', label: 'Unmapped Folders', isVisible: true }, { name: 'actions', isVisible: true } ]; class ImportArtistSelectFolder extends Component { // // Lifecycle constructor(props, context) { super(props, context); this.state = { isAddNewRootFolderModalOpen: false }; } // // Lifecycle onAddNewRootFolderPress = () => { this.setState({ isAddNewRootFolderModalOpen: true }); } onNewRootFolderSelect = ({ value }) => { this.props.onNewRootFolderSelect(value); } onAddRootFolderModalClose = () => { this.setState({ isAddNewRootFolderModalOpen: false }); } // // Render render() { const { isFetching, isPopulated, error, items } = this.props; return ( { isFetching && !isPopulated && } { !isFetching && !!error &&
Unable to load root folders
} { !error && isPopulated &&
Import artist(s) you already have
Some tips to ensure the import goes smoothly:
  • Point Lidarr to the folder containing all of your music not a specific artist. eg. "\music\" and not "\music\alien ant farm\"
{ items.length > 0 ?
{ items.map((rootFolder) => { return ( ); }) }
:
}
}
); } } ImportArtistSelectFolder.propTypes = { isFetching: PropTypes.bool.isRequired, isPopulated: PropTypes.bool.isRequired, error: PropTypes.object, items: PropTypes.arrayOf(PropTypes.object).isRequired, onNewRootFolderSelect: PropTypes.func.isRequired, onDeleteRootFolderPress: PropTypes.func.isRequired }; export default ImportArtistSelectFolder;