Sonarr/frontend/src/Settings/Indexers/IndexerSettings.js

121 lines
3.0 KiB
JavaScript
Raw Normal View History

2018-01-13 02:01:27 +00:00
import PropTypes from 'prop-types';
import React, { Component, Fragment } from 'react';
import PageContent from 'Components/Page/PageContent';
import PageContentBody from 'Components/Page/PageContentBody';
2018-01-13 02:01:27 +00:00
import PageToolbarButton from 'Components/Page/Toolbar/PageToolbarButton';
import PageToolbarSeparator from 'Components/Page/Toolbar/PageToolbarSeparator';
2022-05-20 04:15:43 +00:00
import { icons } from 'Helpers/Props';
2018-01-13 02:01:27 +00:00
import SettingsToolbarConnector from 'Settings/SettingsToolbarConnector';
import translate from 'Utilities/String/translate';
2018-01-13 02:01:27 +00:00
import IndexersConnector from './Indexers/IndexersConnector';
import ManageIndexersModal from './Indexers/Manage/ManageIndexersModal';
2018-01-13 02:01:27 +00:00
import IndexerOptionsConnector from './Options/IndexerOptionsConnector';
class IndexerSettings extends Component {
//
// Lifecycle
constructor(props, context) {
super(props, context);
this._saveCallback = null;
this.state = {
isSaving: false,
hasPendingChanges: false,
isManageIndexersOpen: false
2018-01-13 02:01:27 +00:00
};
}
//
// Listeners
onChildMounted = (saveCallback) => {
this._saveCallback = saveCallback;
2022-05-20 04:15:43 +00:00
};
2018-01-13 02:01:27 +00:00
onChildStateChange = (payload) => {
this.setState(payload);
2022-05-20 04:15:43 +00:00
};
2018-01-13 02:01:27 +00:00
onManageIndexersPress = () => {
this.setState({ isManageIndexersOpen: true });
};
onManageIndexersModalClose = () => {
this.setState({ isManageIndexersOpen: false });
};
2018-01-13 02:01:27 +00:00
onSavePress = () => {
if (this._saveCallback) {
this._saveCallback();
}
2022-05-20 04:15:43 +00:00
};
2018-01-13 02:01:27 +00:00
// Render
//
render() {
const {
isTestingAll,
dispatchTestAllIndexers
} = this.props;
const {
isSaving,
hasPendingChanges,
isManageIndexersOpen
2018-01-13 02:01:27 +00:00
} = this.state;
return (
2023-07-22 19:14:33 +00:00
<PageContent title={translate('IndexerSettings')}>
2018-01-13 02:01:27 +00:00
<SettingsToolbarConnector
isSaving={isSaving}
hasPendingChanges={hasPendingChanges}
additionalButtons={
<Fragment>
<PageToolbarSeparator />
<PageToolbarButton
2023-07-22 19:14:33 +00:00
label={translate('TestAllIndexers')}
2018-01-13 02:01:27 +00:00
iconName={icons.TEST}
isSpinning={isTestingAll}
onPress={dispatchTestAllIndexers}
/>
<PageToolbarButton
label={translate('ManageIndexers')}
iconName={icons.MANAGE}
onPress={this.onManageIndexersPress}
/>
2018-01-13 02:01:27 +00:00
</Fragment>
}
onSavePress={this.onSavePress}
/>
<PageContentBody>
2018-01-13 02:01:27 +00:00
<IndexersConnector />
<IndexerOptionsConnector
onChildMounted={this.onChildMounted}
onChildStateChange={this.onChildStateChange}
/>
<ManageIndexersModal
isOpen={isManageIndexersOpen}
onModalClose={this.onManageIndexersModalClose}
/>
</PageContentBody>
2018-01-13 02:01:27 +00:00
</PageContent>
);
}
}
IndexerSettings.propTypes = {
isTestingAll: PropTypes.bool.isRequired,
dispatchTestAllIndexers: PropTypes.func.isRequired
};
export default IndexerSettings;