From 9f7eeb0510365deb48a0b12b431f4a99d74f11f6 Mon Sep 17 00:00:00 2001 From: Roman Musin Date: Wed, 20 May 2020 17:46:01 +0100 Subject: [PATCH] Mobile: Resolves #2669: When attaching a file insert it at the current cursor position (#3189) * When attaching an image/resource insert it at the current cursor position * Correct argument order * Address code review comments * Another code review comment Co-authored-by: Laurent Cozic --- .../lib/components/screens/note.js | 31 +++++++++++++++++-- 1 file changed, 29 insertions(+), 2 deletions(-) diff --git a/ReactNativeClient/lib/components/screens/note.js b/ReactNativeClient/lib/components/screens/note.js index f6b2994a33..b4993a1ad9 100644 --- a/ReactNativeClient/lib/components/screens/note.js +++ b/ReactNativeClient/lib/components/screens/note.js @@ -72,6 +72,8 @@ class NoteScreenComponent extends BaseScreenComponent { HACK_webviewLoadingState: 0, }; + this.selection = null; + this.markdownEditorRef = React.createRef(); // For focusing the Markdown editor this.doFocusUpdate_ = false; @@ -291,6 +293,8 @@ class NoteScreenComponent extends BaseScreenComponent { } async UNSAFE_componentWillMount() { + this.selection = null; + BackButtonService.addHandler(this.backHandler); NavService.addHandler(this.navHandler); @@ -556,7 +560,15 @@ class NoteScreenComponent extends BaseScreenComponent { const resourceTag = Resource.markdownTag(resource); const newNote = Object.assign({}, this.state.note); - newNote.body += `\n${resourceTag}`; + + if (this.state.mode == 'edit' && !Setting.value('editor.beta') && !!this.selection) { + const prefix = newNote.body.substring(0, this.selection.start); + const suffix = newNote.body.substring(this.selection.end); + newNote.body = `${prefix}\n${resourceTag}\n${suffix}`; + } else { + newNote.body += `\n${resourceTag}`; + } + this.setState({ note: newNote }); this.refreshResource(resource, newNote.body); @@ -979,7 +991,22 @@ class NoteScreenComponent extends BaseScreenComponent { // a plain TextInput for now. // See https://github.com/laurent22/joplin/issues/3041 ( - this.body_changeText(text)} blurOnSubmit={false} selectionColor={theme.textSelectionColor} keyboardAppearance={theme.keyboardAppearance} placeholder={_('Add body')} placeholderTextColor={theme.colorFaded} /> + this.body_changeText(text)} + onSelectionChange={({ nativeEvent: { selection } }) => { + this.selection = selection; + }} + blurOnSubmit={false} + selectionColor={theme.textSelectionColor} + keyboardAppearance={theme.keyboardAppearance} + placeholder={_('Add body')} + placeholderTextColor={theme.colorFaded} + /> ); }