1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-23 18:53:36 +02:00
joplin/packages/app-desktop/gui/ImportScreen.jsx

128 lines
3.4 KiB
React
Raw Normal View History

2017-11-11 17:36:47 +00:00
const React = require('react');
const { connect } = require('react-redux');
const Folder = require('@joplin/lib/models/Folder').default;
const { themeStyle } = require('@joplin/lib/theme');
const { _ } = require('@joplin/lib/locale');
const { filename, basename } = require('@joplin/lib/path-utils');
const importEnex = require('@joplin/lib/import-enex').default;
2017-11-11 17:36:47 +00:00
class ImportScreenComponent extends React.Component {
UNSAFE_componentWillMount() {
2017-11-11 17:36:47 +00:00
this.setState({
doImport: true,
filePath: this.props.filePath,
messages: [],
});
}
UNSAFE_componentWillReceiveProps(newProps) {
2017-11-11 17:36:47 +00:00
if (newProps.filePath) {
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();
messages.push({ key: key, text: text });
2017-11-11 17:36:47 +00:00
this.setState({ messages: messages });
}
uniqueMessages() {
const output = [];
const messages = this.state.messages.slice();
const foundKeys = [];
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;
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 = {
onProgress: progressState => {
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);
},
onError: error => {
// 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
},
};
2017-11-11 17:36:47 +00:00
2017-11-11 23:13:14 +00:00
const folder = await Folder.save({ title: folderTitle });
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);
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={{}}>
<div style={messagesStyle}>{messageComps}</div>
2017-11-11 17:36:47 +00:00
</div>
);
}
}
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);
module.exports = { ImportScreen };