Jelajahi Sumber

User mentions now return @username (full name)

Ben0it-T 3 tahun lalu
induk
melakukan
a160b662ef
2 mengubah file dengan 14 tambahan dan 5 penghapusan
  1. 13 4
      client/components/main/editor.js
  2. 1 1
      models/activities.js

+ 13 - 4
client/components/main/editor.js

@@ -11,7 +11,7 @@ BlazeComponent.extendComponent({
     const mentions = [
       // User mentions
       {
-        match: /\B@([\w.]*)$/,
+        match: /\B@([\w.-]*)$/,
         search(term, callback) {
           const currentBoard = Boards.findOne(Session.get('currentBoard'));
           callback(
@@ -21,8 +21,17 @@ BlazeComponent.extendComponent({
               .map(member => {
                 const user = Users.findOne(member.userId);
                 const username = user.username;
-                const fullName = user.profile && user.profile !== undefined ?  user.profile.fullname : "";
-                return username.includes(term) || fullName.includes(term) ?  fullName + "(" + username + ")" : null;
+                const fullName = user.profile && user.profile !== undefined && user.profile.fullname ? user.profile.fullname : "";
+                // return username.includes(term) || fullName.includes(term) ?  fullName + "(" + username + ")" : null;
+                if (username.includes(term) || fullName.includes(term)) {
+                  if (fullName) {
+                    return username + " (" + fullName + ")";
+                  }
+                  else {
+                    return username;
+                  }
+                }
+                return null;
               })
               .filter(Boolean), [...specialHandleNames])
           );
@@ -355,7 +364,7 @@ Blaze.Template.registerHelper(
       }
       return member;
     }), [...specialHandles]);
-    const mentionRegex = /\B@([\w.]*)/gi;
+    const mentionRegex = /\B@([\w.-]*)/gi;
 
     let currentMention;
     while ((currentMention = mentionRegex.exec(content)) !== null) {

+ 1 - 1
models/activities.js

@@ -202,7 +202,7 @@ if (Meteor.isServer) {
           }
           return member;
         });
-        const mentionRegex = /\B@(?:(?:"([\w.\s]*)")|([\w.]+))/gi; // including space in username
+        const mentionRegex = /\B@(?:(?:"([\w.\s-]*)")|([\w.-]+))/gi; // including space in username
         let currentMention;
         while ((currentMention = mentionRegex.exec(comment)) !== null) {
           /*eslint no-unused-vars: ["error", { "varsIgnorePattern": "[iI]gnored" }]*/