const React = require('react'); const { View, StyleSheet } = require('react-native'); const { connect } = require('react-redux'); const Folder = require('@joplin/lib/models/Folder').default; const BaseModel = require('@joplin/lib/BaseModel').default; const { ScreenHeader } = require('../ScreenHeader'); const { BaseScreenComponent } = require('../base-screen.js'); const { dialogs } = require('../../utils/dialogs.js'); const { _ } = require('@joplin/lib/locale'); const { default: FolderPicker } = require('../FolderPicker'); const TextInput = require('../TextInput').default; class FolderScreenComponent extends BaseScreenComponent { static navigationOptions() { return { header: null }; } constructor() { super(); this.state = { folder: Folder.new(), lastSavedFolder: null, }; } UNSAFE_componentWillMount() { if (!this.props.folderId) { const folder = Folder.new(); this.setState({ folder: folder, lastSavedFolder: Object.assign({}, folder), }); } else { // eslint-disable-next-line promise/prefer-await-to-then -- Old code before rule was applied Folder.load(this.props.folderId).then(folder => { this.setState({ folder: folder, lastSavedFolder: Object.assign({}, folder), }); }); } } isModified() { if (!this.state.folder || !this.state.lastSavedFolder) return false; const diff = BaseModel.diffObjects(this.state.folder, this.state.lastSavedFolder); delete diff.type_; return !!Object.getOwnPropertyNames(diff).length; } folderComponent_change(propName, propValue) { this.setState((prevState) => { const folder = Object.assign({}, prevState.folder); folder[propName] = propValue; return { folder: folder }; }); } title_changeText(text) { this.folderComponent_change('title', text); } parent_changeValue(parent) { this.folderComponent_change('parent_id', parent); } async saveFolderButton_press() { let folder = Object.assign({}, this.state.folder); try { if (folder.id && !(await Folder.canNestUnder(folder.id, folder.parent_id))) throw new Error(_('Cannot move notebook to this location')); folder = await Folder.save(folder, { userSideValidation: true }); } catch (error) { dialogs.error(this, _('The notebook could not be saved: %s', error.message)); return; } this.setState({ lastSavedFolder: Object.assign({}, folder), folder: folder, }); this.props.dispatch({ type: 'NAV_GO', routeName: 'Notes', folderId: folder.id, }); } render() { const saveButtonDisabled = !this.isModified() || !this.state.folder.title; return ( this.saveFolderButton_press()} showSideMenuButton={false} showSearchButton={false} /> this.title_changeText(text)} disabled={this.state.folder.encryption_applied} /> this.parent_changeValue(newValue)} mustSelect darkText /> { this.dialogbox = dialogbox; }} /> ); } } const FolderScreen = connect(state => { return { folderId: state.selectedFolderId, themeId: state.settings.theme, folders: state.folders.filter((folder) => folder.id !== state.selectedFolderId), }; })(FolderScreenComponent); const styles = StyleSheet.create({ folderPickerContainer: { height: 46, paddingLeft: 14, paddingRight: 14, paddingTop: 12, paddingBottom: 12, }, }); module.exports = { FolderScreen };