2017-11-11 17:36:47 +00:00
|
|
|
const React = require('react');
|
|
|
|
const { connect } = require('react-redux');
|
2021-01-22 17:41:11 +00:00
|
|
|
const Folder = require('@joplin/lib/models/Folder').default;
|
2020-11-07 15:59:37 +00:00
|
|
|
const { themeStyle } = require('@joplin/lib/theme');
|
|
|
|
const { _ } = require('@joplin/lib/locale');
|
|
|
|
const { filename, basename } = require('@joplin/lib/path-utils');
|
2021-09-23 13:15:31 +01:00
|
|
|
const importEnex = require('@joplin/lib/import-enex').default;
|
2017-11-11 17:36:47 +00:00
|
|
|
|
|
|
|
class ImportScreenComponent extends React.Component {
|
2019-12-13 01:16:34 +00:00
|
|
|
UNSAFE_componentWillMount() {
|
2017-11-11 17:36:47 +00:00
|
|
|
this.setState({
|
|
|
|
doImport: true,
|
|
|
|
filePath: this.props.filePath,
|
|
|
|
messages: [],
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2019-12-13 01:16:34 +00:00
|
|
|
UNSAFE_componentWillReceiveProps(newProps) {
|
2017-11-11 17:36:47 +00:00
|
|
|
if (newProps.filePath) {
|
2019-07-29 14:13:23 +02:00
|
|
|
this.setState(
|
|
|
|
{
|
|
|
|
doImport: true,
|
|
|
|
filePath: newProps.filePath,
|
|
|
|
messages: [],
|
|
|
|
},
|
|
|
|
() => {
|
|
|
|
this.doImport();
|
|
|
|
}
|
|
|
|
);
|
2017-11-11 17:36:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
componentDidMount() {
|
|
|
|
if (this.state.filePath && this.state.doImport) {
|
|
|
|
this.doImport();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
addMessage(key, text) {
|
|
|
|
const messages = this.state.messages.slice();
|
|
|
|
|
2017-12-07 00:57:36 +00:00
|
|
|
messages.push({ key: key, text: text });
|
2017-11-11 17:36:47 +00:00
|
|
|
|
|
|
|
this.setState({ messages: messages });
|
|
|
|
}
|
|
|
|
|
2017-12-07 00:57:36 +00:00
|
|
|
uniqueMessages() {
|
2020-03-13 23:46:14 +00:00
|
|
|
const output = [];
|
2017-12-07 00:57:36 +00:00
|
|
|
const messages = this.state.messages.slice();
|
2020-03-13 23:46:14 +00:00
|
|
|
const foundKeys = [];
|
2017-12-07 00:57:36 +00:00
|
|
|
for (let i = messages.length - 1; i >= 0; i--) {
|
|
|
|
const msg = messages[i];
|
|
|
|
if (foundKeys.indexOf(msg.key) >= 0) continue;
|
|
|
|
foundKeys.push(msg.key);
|
|
|
|
output.unshift(msg);
|
|
|
|
}
|
|
|
|
return output;
|
|
|
|
}
|
|
|
|
|
2017-11-11 17:36:47 +00:00
|
|
|
async doImport() {
|
|
|
|
const filePath = this.props.filePath;
|
2018-06-27 21:45:31 +01:00
|
|
|
const folderTitle = await Folder.findUniqueItemTitle(filename(filePath));
|
2017-11-11 17:36:47 +00:00
|
|
|
|
|
|
|
this.addMessage('start', _('New notebook "%s" will be created and file "%s" will be imported into it', folderTitle, basename(filePath)));
|
|
|
|
|
|
|
|
let lastProgress = '';
|
|
|
|
|
|
|
|
const options = {
|
2020-05-21 09:14:33 +01:00
|
|
|
onProgress: progressState => {
|
2020-03-13 23:46:14 +00:00
|
|
|
const line = [];
|
2017-11-11 17:36:47 +00:00
|
|
|
line.push(_('Found: %d.', progressState.loaded));
|
|
|
|
line.push(_('Created: %d.', progressState.created));
|
|
|
|
if (progressState.updated) line.push(_('Updated: %d.', progressState.updated));
|
|
|
|
if (progressState.skipped) line.push(_('Skipped: %d.', progressState.skipped));
|
|
|
|
if (progressState.resourcesCreated) line.push(_('Resources: %d.', progressState.resourcesCreated));
|
|
|
|
if (progressState.notesTagged) line.push(_('Tagged: %d.', progressState.notesTagged));
|
|
|
|
lastProgress = line.join(' ');
|
|
|
|
this.addMessage('progress', lastProgress);
|
|
|
|
},
|
2020-05-21 09:14:33 +01:00
|
|
|
onError: error => {
|
2017-12-07 00:57:36 +00:00
|
|
|
// Don't display the error directly because most of the time it doesn't matter
|
|
|
|
// (eg. for weird broken HTML, but the note is still imported)
|
|
|
|
console.warn('When importing ENEX file', error);
|
2017-11-11 17:36:47 +00:00
|
|
|
},
|
2019-07-29 14:13:23 +02:00
|
|
|
};
|
2017-11-11 17:36:47 +00:00
|
|
|
|
2017-11-11 23:13:14 +00:00
|
|
|
const folder = await Folder.save({ title: folderTitle });
|
2019-07-29 14:13:23 +02:00
|
|
|
|
2017-11-11 23:13:14 +00:00
|
|
|
await importEnex(folder.id, filePath, options);
|
2017-11-11 17:36:47 +00:00
|
|
|
|
|
|
|
this.addMessage('done', _('The notes have been imported: %s', lastProgress));
|
|
|
|
this.setState({ doImport: false });
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
2020-09-15 14:01:07 +01:00
|
|
|
const theme = themeStyle(this.props.themeId);
|
2017-12-07 00:57:36 +00:00
|
|
|
const messages = this.uniqueMessages();
|
2017-11-11 17:36:47 +00:00
|
|
|
|
|
|
|
const messagesStyle = {
|
|
|
|
padding: 10,
|
|
|
|
fontSize: theme.fontSize,
|
|
|
|
fontFamily: theme.fontFamily,
|
|
|
|
backgroundColor: theme.backgroundColor,
|
|
|
|
};
|
|
|
|
|
|
|
|
const messageComps = [];
|
|
|
|
for (let i = 0; i < messages.length; i++) {
|
|
|
|
messageComps.push(<div key={messages[i].key}>{messages[i].text}</div>);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div style={{}}>
|
2019-07-29 14:13:23 +02:00
|
|
|
<div style={messagesStyle}>{messageComps}</div>
|
2017-11-11 17:36:47 +00:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-21 09:14:33 +01:00
|
|
|
const mapStateToProps = state => {
|
2017-11-11 17:36:47 +00:00
|
|
|
return {
|
2020-09-15 14:01:07 +01:00
|
|
|
themeId: state.settings.theme,
|
2017-11-11 17:36:47 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
const ImportScreen = connect(mapStateToProps)(ImportScreenComponent);
|
|
|
|
|
2019-07-29 14:13:23 +02:00
|
|
|
module.exports = { ImportScreen };
|