|
|
@ -2,8 +2,9 @@ import PropTypes from 'prop-types';
|
|
|
|
import React, { Component } from 'react';
|
|
|
|
import React, { Component } from 'react';
|
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import { createSelector } from 'reselect';
|
|
|
|
import { createSelector } from 'reselect';
|
|
|
|
import { deleteMovieFile, setMovieFilesTableOption, updateMovieFiles } from 'Store/Actions/movieFileActions';
|
|
|
|
import { deleteMovieFile, setMovieFilesSort, setMovieFilesTableOption } from 'Store/Actions/movieFileActions';
|
|
|
|
import { fetchLanguages, fetchQualityProfileSchema } from 'Store/Actions/settingsActions';
|
|
|
|
import { fetchLanguages, fetchQualityProfileSchema } from 'Store/Actions/settingsActions';
|
|
|
|
|
|
|
|
import createClientSideCollectionSelector from 'Store/Selectors/createClientSideCollectionSelector';
|
|
|
|
import createMovieSelector from 'Store/Selectors/createMovieSelector';
|
|
|
|
import createMovieSelector from 'Store/Selectors/createMovieSelector';
|
|
|
|
import getQualities from 'Utilities/Quality/getQualities';
|
|
|
|
import getQualities from 'Utilities/Quality/getQualities';
|
|
|
|
import MovieFileEditorTableContent from './MovieFileEditorTableContent';
|
|
|
|
import MovieFileEditorTableContent from './MovieFileEditorTableContent';
|
|
|
@ -11,7 +12,7 @@ import MovieFileEditorTableContent from './MovieFileEditorTableContent';
|
|
|
|
function createMapStateToProps() {
|
|
|
|
function createMapStateToProps() {
|
|
|
|
return createSelector(
|
|
|
|
return createSelector(
|
|
|
|
(state, { movieId }) => movieId,
|
|
|
|
(state, { movieId }) => movieId,
|
|
|
|
(state) => state.movieFiles,
|
|
|
|
createClientSideCollectionSelector('movieFiles'),
|
|
|
|
(state) => state.settings.languages,
|
|
|
|
(state) => state.settings.languages,
|
|
|
|
(state) => state.settings.qualityProfiles,
|
|
|
|
(state) => state.settings.qualityProfiles,
|
|
|
|
createMovieSelector(),
|
|
|
|
createMovieSelector(),
|
|
|
@ -28,6 +29,8 @@ function createMapStateToProps() {
|
|
|
|
return {
|
|
|
|
return {
|
|
|
|
items: filesForMovie,
|
|
|
|
items: filesForMovie,
|
|
|
|
columns: movieFiles.columns,
|
|
|
|
columns: movieFiles.columns,
|
|
|
|
|
|
|
|
sortKey: movieFiles.sortKey,
|
|
|
|
|
|
|
|
sortDirection: movieFiles.sortDirection,
|
|
|
|
isDeleting: movieFiles.isDeleting,
|
|
|
|
isDeleting: movieFiles.isDeleting,
|
|
|
|
isSaving: movieFiles.isSaving,
|
|
|
|
isSaving: movieFiles.isSaving,
|
|
|
|
error: null,
|
|
|
|
error: null,
|
|
|
@ -38,31 +41,13 @@ function createMapStateToProps() {
|
|
|
|
);
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function createMapDispatchToProps(dispatch, props) {
|
|
|
|
const mapDispatchToProps = {
|
|
|
|
return {
|
|
|
|
fetchQualityProfileSchema,
|
|
|
|
dispatchFetchQualityProfileSchema() {
|
|
|
|
fetchLanguages,
|
|
|
|
dispatch(fetchQualityProfileSchema());
|
|
|
|
deleteMovieFile,
|
|
|
|
},
|
|
|
|
setMovieFilesTableOption,
|
|
|
|
|
|
|
|
setMovieFilesSort
|
|
|
|
dispatchFetchLanguages() {
|
|
|
|
|
|
|
|
dispatch(fetchLanguages());
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
dispatchUpdateMovieFiles(updateProps) {
|
|
|
|
|
|
|
|
dispatch(updateMovieFiles(updateProps));
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
onTableOptionChange(payload) {
|
|
|
|
|
|
|
|
dispatch(setMovieFilesTableOption(payload));
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
onDeletePress(movieFileId) {
|
|
|
|
|
|
|
|
dispatch(deleteMovieFile({
|
|
|
|
|
|
|
|
id: movieFileId
|
|
|
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class MovieFileEditorTableContentConnector extends Component {
|
|
|
|
class MovieFileEditorTableContentConnector extends Component {
|
|
|
|
|
|
|
|
|
|
|
@ -70,24 +55,40 @@ class MovieFileEditorTableContentConnector extends Component {
|
|
|
|
// Lifecycle
|
|
|
|
// Lifecycle
|
|
|
|
|
|
|
|
|
|
|
|
componentDidMount() {
|
|
|
|
componentDidMount() {
|
|
|
|
this.props.dispatchFetchLanguages();
|
|
|
|
this.props.fetchLanguages();
|
|
|
|
this.props.dispatchFetchQualityProfileSchema();
|
|
|
|
this.props.fetchQualityProfileSchema();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
|
|
|
// Listeners
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
onDeletePress = (movieFileId) => {
|
|
|
|
|
|
|
|
this.props.deleteMovieFile({
|
|
|
|
|
|
|
|
id: movieFileId
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
onTableOptionChange = (payload) => {
|
|
|
|
|
|
|
|
this.props.setMovieFilesTableOption(payload);
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
onSortPress = (sortKey, sortDirection) => {
|
|
|
|
|
|
|
|
this.props.setMovieFilesSort({
|
|
|
|
|
|
|
|
sortKey,
|
|
|
|
|
|
|
|
sortDirection
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// Render
|
|
|
|
// Render
|
|
|
|
|
|
|
|
|
|
|
|
render() {
|
|
|
|
render() {
|
|
|
|
const {
|
|
|
|
|
|
|
|
dispatchFetchLanguages,
|
|
|
|
|
|
|
|
dispatchFetchQualityProfileSchema,
|
|
|
|
|
|
|
|
dispatchUpdateMovieFiles,
|
|
|
|
|
|
|
|
...otherProps
|
|
|
|
|
|
|
|
} = this.props;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
return (
|
|
|
|
<MovieFileEditorTableContent
|
|
|
|
<MovieFileEditorTableContent
|
|
|
|
{...otherProps}
|
|
|
|
{...this.props}
|
|
|
|
|
|
|
|
onDeletePress={this.onDeletePress}
|
|
|
|
|
|
|
|
onTableOptionChange={this.onTableOptionChange}
|
|
|
|
|
|
|
|
onSortPress={this.onSortPress}
|
|
|
|
/>
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -97,9 +98,11 @@ MovieFileEditorTableContentConnector.propTypes = {
|
|
|
|
movieId: PropTypes.number.isRequired,
|
|
|
|
movieId: PropTypes.number.isRequired,
|
|
|
|
languages: PropTypes.arrayOf(PropTypes.object).isRequired,
|
|
|
|
languages: PropTypes.arrayOf(PropTypes.object).isRequired,
|
|
|
|
qualities: PropTypes.arrayOf(PropTypes.object).isRequired,
|
|
|
|
qualities: PropTypes.arrayOf(PropTypes.object).isRequired,
|
|
|
|
dispatchFetchLanguages: PropTypes.func.isRequired,
|
|
|
|
fetchLanguages: PropTypes.func.isRequired,
|
|
|
|
dispatchFetchQualityProfileSchema: PropTypes.func.isRequired,
|
|
|
|
fetchQualityProfileSchema: PropTypes.func.isRequired,
|
|
|
|
dispatchUpdateMovieFiles: PropTypes.func.isRequired
|
|
|
|
deleteMovieFile: PropTypes.func.isRequired,
|
|
|
|
|
|
|
|
setMovieFilesTableOption: PropTypes.func.isRequired,
|
|
|
|
|
|
|
|
setMovieFilesSort: PropTypes.func.isRequired
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
export default connect(createMapStateToProps, createMapDispatchToProps)(MovieFileEditorTableContentConnector);
|
|
|
|
export default connect(createMapStateToProps, mapDispatchToProps)(MovieFileEditorTableContentConnector);
|
|
|
|