summaryrefslogtreecommitdiffstats
path: root/apps/comments
diff options
context:
space:
mode:
authorLouis Chemineau <louis@chmn.me>2022-11-15 18:30:17 +0100
committerLouis Chemineau <louis@chmn.me>2022-11-23 13:47:24 +0100
commit19042c4d91886b57967c87cd132dbb346843d0af (patch)
tree2339ef24f2aed44f297fefdbc6aaf368f5bc081b /apps/comments
parent5efabd1fa90c43fc6e181c717620eb0203021806 (diff)
downloadnextcloud-server-19042c4d91886b57967c87cd132dbb346843d0af.tar.gz
nextcloud-server-19042c4d91886b57967c87cd132dbb346843d0af.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.vue1
-rw-r--r--apps/comments/src/views/Comments.vue39
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))
},
/**