diff options
author | Louis Chemineau <louis@chmn.me> | 2022-11-15 18:30:17 +0100 |
---|---|---|
committer | Louis Chemineau <louis@chmn.me> | 2022-11-21 10:48:47 +0100 |
commit | 0f6680669449b42ae28852d2d085d2a893f92bc4 (patch) | |
tree | 1324b46c3f1e38300e0fe76989930ce526464826 /apps/comments | |
parent | aad8b303985543fab9b9f9c01b6cca9dc4f7807e (diff) | |
download | nextcloud-server-0f6680669449b42ae28852d2d085d2a893f92bc4.tar.gz nextcloud-server-0f6680669449b42ae28852d2d085d2a893f92bc4.zip |
Fix mentions rendering in comment editor
NcRichContentEditable needs an index of users to properly display them. This commit adds a caching logic and provides it to NcRichContentEditable.
Signed-off-by: Louis Chemineau <louis@chmn.me>
Diffstat (limited to 'apps/comments')
-rw-r--r-- | apps/comments/src/components/Comment.vue | 1 | ||||
-rw-r--r-- | apps/comments/src/views/Comments.vue | 39 |
2 files changed, 23 insertions, 17 deletions
diff --git a/apps/comments/src/components/Comment.vue b/apps/comments/src/components/Comment.vue index 41284e50ca9..062dda74756 100644 --- a/apps/comments/src/components/Comment.vue +++ b/apps/comments/src/components/Comment.vue @@ -69,6 +69,7 @@ :auto-complete="autoComplete" :contenteditable="!loading" :value="localMessage" + :user-data="userData" @update:value="updateLocalMessage" @submit="onSubmit" /> <NcButton class="comment__submit" diff --git a/apps/comments/src/views/Comments.vue b/apps/comments/src/views/Comments.vue index 170c3c937b5..288fe44e96b 100644 --- a/apps/comments/src/views/Comments.vue +++ b/apps/comments/src/views/Comments.vue @@ -26,6 +26,7 @@ <!-- Editor --> <Comment v-bind="editorData" :auto-complete="autoComplete" + :user-data="userData" :editor="true" :ressource-id="ressourceId" class="comments__writer" @@ -91,9 +92,9 @@ import RefreshIcon from 'vue-material-design-icons/Refresh' import MessageReplyTextIcon from 'vue-material-design-icons/MessageReplyText' import AlertCircleOutlineIcon from 'vue-material-design-icons/AlertCircleOutline' -import Comment from '../components/Comment' -import getComments, { DEFAULT_LIMIT } from '../services/GetComments' -import cancelableRequest from '../utils/cancelableRequest' +import Comment from '../components/Comment.vue' +import getComments, { DEFAULT_LIMIT } from '../services/GetComments.js' +import cancelableRequest from '../utils/cancelableRequest.js' Vue.use(VTooltip) @@ -129,6 +130,7 @@ export default { }, Comment, + userData: {}, } }, @@ -173,21 +175,22 @@ export default { * Make sure we have all mentions as Array of objects * * @param {Array} mentions the mentions list - * @return {object[]} + * @return {Object<string, object>} */ genMentionsData(mentions) { - const list = Object.values(mentions).flat() - return list.reduce((mentions, mention) => { - mentions[mention.mentionId] = { - // TODO: support groups - icon: 'icon-user', - id: mention.mentionId, - label: mention.mentionDisplayName, - source: 'users', - primary: getCurrentUser().uid === mention.mentionId, - } - return mentions - }, {}) + Object.values(mentions) + .flat() + .forEach(mention => { + this.userData[mention.mentionId] = { + // TODO: support groups + icon: 'icon-user', + id: mention.mentionId, + label: mention.mentionDisplayName, + source: 'users', + primary: getCurrentUser().uid === mention.mentionId, + } + }) + return this.userData }, /** @@ -251,7 +254,9 @@ export default { limit: loadState('comments', 'maxAutoCompleteResults'), }, }) - return callback(results.data.ocs.data) + // Save user data so it can be used by the editor to replace mentions + results.data.ocs.data.forEach(user => { this.userData[user.id] = user }) + return callback(Object.values(this.userData)) }, /** |