Radarr/frontend/src/Settings/Metadata/MetadataSettings.js

73 lines
1.5 KiB
JavaScript
Raw Normal View History

2020-04-03 00:57:36 +00:00
import React, { Component } from 'react';
2018-11-23 07:04:42 +00:00
import PageContent from 'Components/Page/PageContent';
import PageContentBody from 'Components/Page/PageContentBody';
2018-11-23 07:04:42 +00:00
import SettingsToolbarConnector from 'Settings/SettingsToolbarConnector';
2020-08-29 03:56:13 +00:00
import translate from 'Utilities/String/translate';
2018-11-23 07:04:42 +00:00
import MetadatasConnector from './Metadata/MetadatasConnector';
2020-04-03 00:57:36 +00:00
import MetadataOptionsConnector from './Options/MetadataOptionsConnector';
2018-11-23 07:04:42 +00:00
2020-04-03 00:57:36 +00:00
class MetadataSettings extends Component {
//
// Lifecycle
constructor(props, context) {
super(props, context);
this._saveCallback = null;
this.state = {
isSaving: false,
hasPendingChanges: false
};
}
//
// Listeners
onChildMounted = (saveCallback) => {
this._saveCallback = saveCallback;
}
onChildStateChange = (payload) => {
this.setState(payload);
}
onSavePress = () => {
if (this._saveCallback) {
this._saveCallback();
}
}
2020-06-27 22:13:31 +00:00
//
// Render
2020-06-28 15:55:49 +00:00
2020-04-03 00:57:36 +00:00
render() {
const {
isSaving,
hasPendingChanges
} = this.state;
return (
2020-08-29 03:56:13 +00:00
<PageContent title={translate('MetadataSettings')}>
2020-04-03 00:57:36 +00:00
<SettingsToolbarConnector
isSaving={isSaving}
hasPendingChanges={hasPendingChanges}
onSavePress={this.onSavePress}
/>
<PageContentBody>
2020-04-03 00:57:36 +00:00
<MetadataOptionsConnector
onChildMounted={this.onChildMounted}
onChildStateChange={this.onChildStateChange}
/>
<MetadatasConnector />
</PageContentBody>
2020-04-03 00:57:36 +00:00
</PageContent>
);
}
2018-11-23 07:04:42 +00:00
}
export default MetadataSettings;