nodebb-plugin-mentions 4.0.6 → 4.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/.eslintrc +2 -2
  2. package/LICENSE +7 -7
  3. package/README.md +13 -13
  4. package/languages/ar/notifications.json +2 -2
  5. package/languages/bg/notifications.json +2 -2
  6. package/languages/bn/notifications.json +2 -2
  7. package/languages/da/notifications.json +2 -2
  8. package/languages/de/notifications.json +5 -5
  9. package/languages/el/notifications.json +2 -2
  10. package/languages/en@pirate/notifications.json +4 -4
  11. package/languages/en_GB/mentions.json +3 -3
  12. package/languages/en_GB/notifications.json +6 -6
  13. package/languages/en_US/notifications.json +4 -4
  14. package/languages/es/notifications.json +3 -3
  15. package/languages/et/notifications.json +2 -2
  16. package/languages/fa_IR/notifications.json +4 -4
  17. package/languages/fi/notifications.json +2 -2
  18. package/languages/fr/notifications.json +5 -5
  19. package/languages/gl/notifications.json +2 -2
  20. package/languages/he/notifications.json +4 -1
  21. package/languages/id/notifications.json +2 -2
  22. package/languages/it/notifications.json +3 -3
  23. package/languages/ja/notifications.json +4 -4
  24. package/languages/jbo/notifications.json +4 -4
  25. package/languages/ko/notifications.json +2 -2
  26. package/languages/lt/notifications.json +2 -2
  27. package/languages/ms/notifications.json +2 -2
  28. package/languages/nl/notifications.json +2 -2
  29. package/languages/pl/mentions.json +3 -3
  30. package/languages/pl/notifications.json +6 -6
  31. package/languages/pt-PT/notifications.json +6 -6
  32. package/languages/pt_BR/notifications.json +3 -3
  33. package/languages/ro/notifications.json +2 -2
  34. package/languages/rw/notifications.json +2 -2
  35. package/languages/sl/notifications.json +2 -2
  36. package/languages/sr/notifications.json +2 -2
  37. package/languages/sv/notifications.json +2 -2
  38. package/languages/tr/notifications.json +6 -6
  39. package/languages/vi/notifications.json +2 -2
  40. package/languages/zh-CN/mentions.json +3 -3
  41. package/languages/zh-CN/notifications.json +5 -5
  42. package/languages/zh_TW/notifications.json +2 -2
  43. package/library.js +8 -3
  44. package/package.json +2 -2
  45. package/plugin.json +30 -30
  46. package/static/.eslintrc +3 -3
  47. package/test/index.js +40 -19
package/.eslintrc CHANGED
@@ -1,3 +1,3 @@
1
- {
2
- "extends": "nodebb/lib"
1
+ {
2
+ "extends": "nodebb/lib"
3
3
  }
package/LICENSE CHANGED
@@ -1,8 +1,8 @@
1
- Copyright (c) 2013-2014, Julian Lam <julian@designcreateplay.com>
2
- All rights reserved.
3
-
4
- Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
5
-
6
- Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
7
- Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
1
+ Copyright (c) 2013-2014, Julian Lam <julian@designcreateplay.com>
2
+ All rights reserved.
3
+
4
+ Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
5
+
6
+ Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
7
+ Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
8
8
  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
package/README.md CHANGED
@@ -1,14 +1,14 @@
1
- # Username/Group Mentions
2
-
3
- This NodeBB plugin allows posters to reference (or *mention*) other users or groups on a NodeBB by simply
4
- precluding the `@` symbol before a username.
5
-
6
- A link is automatically added to the post.
7
-
8
- ## Installation
9
-
10
- This plugin is bundled with every NodeBB install. If not, you can install it via the Plugins page of the ACP.
11
-
12
- Alternatively,
13
-
1
+ # Username/Group Mentions
2
+
3
+ This NodeBB plugin allows posters to reference (or *mention*) other users or groups on a NodeBB by simply
4
+ precluding the `@` symbol before a username.
5
+
6
+ A link is automatically added to the post.
7
+
8
+ ## Installation
9
+
10
+ This plugin is bundled with every NodeBB install. If not, you can install it via the Plugins page of the ACP.
11
+
12
+ Alternatively,
13
+
14
14
  npm install nodebb-plugin-mentions
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> ذكرَ اسمك في <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> ذكرَ اسمك في <strong>%2</strong>"
3
3
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> Ви спомена в <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> Ви спомена в <strong>%2</strong>"
3
3
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong>, <strong>%2</strong> এ আপনার নাম উল্লেখ করেছেন"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong>, <strong>%2</strong> এ আপনার নাম উল্লেখ করেছেন"
3
3
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> nævnte dig i <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> nævnte dig i <strong>%2</strong>"
3
3
  }
@@ -1,6 +1,6 @@
1
- {
2
- "mentions": "Erwähnungen",
3
- "user_mentioned_you_in": "<strong>%1</strong> erwähnte dich in <strong>%2</strong>",
4
- "user_mentioned_group_in": "<strong>%1</strong> erwähnte <strong>%2</strong> in <strong>%3</strong>",
5
- "notificationType_mention": "Wenn dich jemand erwähnt"
1
+ {
2
+ "mentions": "Erwähnungen",
3
+ "user_mentioned_you_in": "<strong>%1</strong> erwähnte dich in <strong>%2</strong>",
4
+ "user_mentioned_group_in": "<strong>%1</strong> erwähnte <strong>%2</strong> in <strong>%3</strong>",
5
+ "notificationType_mention": "Wenn dich jemand erwähnt"
6
6
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "Ο/Η <strong>%1</strong> σε ανέφερε στο <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "Ο/Η <strong>%1</strong> σε ανέφερε στο <strong>%2</strong>"
3
3
  }
@@ -1,4 +1,4 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> spoke yer name in <strong>%2</strong>",
3
- "user_mentioned_group_in": "<strong>%1</strong> called fer <strong>%2</strong> in <strong>%3</strong>"
4
- }
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> spoke yer name in <strong>%2</strong>",
3
+ "user_mentioned_group_in": "<strong>%1</strong> called fer <strong>%2</strong> in <strong>%3</strong>"
4
+ }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> mentioned you in <strong>%2</strong>"
3
- }
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> mentioned you in <strong>%2</strong>"
3
+ }
@@ -1,6 +1,6 @@
1
- {
2
- "mentions": "Mentions",
3
- "user_mentioned_you_in": "<strong>%1</strong> mentioned you in <strong>%2</strong>",
4
- "user_mentioned_group_in": "<strong>%1</strong> mentioned <strong>%2</strong> in <strong>%3</strong>",
5
- "notificationType_mention": "When someone mentions you"
6
- }
1
+ {
2
+ "mentions": "Mentions",
3
+ "user_mentioned_you_in": "<strong>%1</strong> mentioned you in <strong>%2</strong>",
4
+ "user_mentioned_group_in": "<strong>%1</strong> mentioned <strong>%2</strong> in <strong>%3</strong>",
5
+ "notificationType_mention": "When someone mentions you"
6
+ }
@@ -1,4 +1,4 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> mentioned you in <strong>%2</strong>",
3
- "user_mentioned_group_in": "<strong>%1</strong> mentioned <strong>%2</strong> in <strong>%3</strong>"
4
- }
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> mentioned you in <strong>%2</strong>",
3
+ "user_mentioned_group_in": "<strong>%1</strong> mentioned <strong>%2</strong> in <strong>%3</strong>"
4
+ }
@@ -1,4 +1,4 @@
1
- {
2
- "mentions": "Menciones",
3
- "user_mentioned_you_in": "<strong>%1</strong> te mencionó en <strong>%2</strong>"
1
+ {
2
+ "mentions": "Menciones",
3
+ "user_mentioned_you_in": "<strong>%1</strong> te mencionó en <strong>%2</strong>"
4
4
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> mainis sind postituses <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> mainis sind postituses <strong>%2</strong>"
3
3
  }
@@ -1,4 +1,4 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> شما رو در <strong>%2</strong> منشن کرده",
3
- "user_mentioned_group_in": "<strong>%1</strong> گروه <strong>%2</strong> رو در <strong>%3</strong> منشن کرده"
4
- }
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> شما رو در <strong>%2</strong> منشن کرده",
3
+ "user_mentioned_group_in": "<strong>%1</strong> گروه <strong>%2</strong> رو در <strong>%3</strong> منشن کرده"
4
+ }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> mainitsi sinut viestissä <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> mainitsi sinut viestissä <strong>%2</strong>"
3
3
  }
@@ -1,6 +1,6 @@
1
- {
2
- "mentions": "Mentions",
3
- "user_mentioned_you_in": "<strong>%1</strong> vous a mentionné dans <strong>%2</strong>",
4
- "user_mentioned_group_in": "<strong>%1</strong> a mentionné <strong>%2</strong> dans <strong>%3</strong>",
5
- "notificationType_mention": "Lorsque quelqu'un vous mentionne"
1
+ {
2
+ "mentions": "Mentions",
3
+ "user_mentioned_you_in": "<strong>%1</strong> vous a mentionné dans <strong>%2</strong>",
4
+ "user_mentioned_group_in": "<strong>%1</strong> a mentionné <strong>%2</strong> dans <strong>%3</strong>",
5
+ "notificationType_mention": "Lorsque quelqu'un vous mentionne"
6
6
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> mencionóute en <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> mencionóute en <strong>%2</strong>"
3
3
  }
@@ -1,3 +1,6 @@
1
1
  {
2
- "user_mentioned_you_in": "<strong>%1</strong> הזכיר אותך ב <strong>%2</strong>"
2
+ "mentions": "אזכורים",
3
+ "user_mentioned_you_in": "<strong>%1</strong> הזכיר אותך ב <strong>%2</strong>",
4
+ "user_mentioned_group_in": "<strong>%1</strong> הזכיר את <strong>%2</strong> ב <strong>%3</strong>",
5
+ "notificationType_mention": "כאשר מישהו מזכיר אותך"
3
6
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> menyebut mu di <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> menyebut mu di <strong>%2</strong>"
3
3
  }
@@ -1,4 +1,4 @@
1
- {
2
- "mentions": "Menzioni",
3
- "user_mentioned_you_in": "<strong>%1</strong> ti ha menzionato in <strong>%2</strong>"
1
+ {
2
+ "mentions": "Menzioni",
3
+ "user_mentioned_you_in": "<strong>%1</strong> ti ha menzionato in <strong>%2</strong>"
4
4
  }
@@ -1,5 +1,5 @@
1
- {
2
- "mentions": "メンション",
3
- "user_mentioned_you_in": "<strong>%1</strong> mentioned you in <strong>%2</strong>",
4
- "user_mentioned_group_in": "<strong>%1</strong> mentioned <strong>%2</strong> in <strong>%3</strong>"
1
+ {
2
+ "mentions": "メンション",
3
+ "user_mentioned_you_in": "<strong>%1</strong> mentioned you in <strong>%2</strong>",
4
+ "user_mentioned_group_in": "<strong>%1</strong> mentioned <strong>%2</strong> in <strong>%3</strong>"
5
5
  }
@@ -1,4 +1,4 @@
1
- {
2
- "user_mentioned_you_in": "la .<strong>%1</strong>. klacpe do la .<strong>%2</strong>.",
3
- "user_mentioned_group_in": "la .<strong>%1</strong>. klacpe la .<strong>%2</strong>. la .<strong>%3</strong>."
4
- }
1
+ {
2
+ "user_mentioned_you_in": "la .<strong>%1</strong>. klacpe do la .<strong>%2</strong>.",
3
+ "user_mentioned_group_in": "la .<strong>%1</strong>. klacpe la .<strong>%2</strong>. la .<strong>%3</strong>."
4
+ }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong>님이 <strong>%2</strong>에서 나를 언급했습니다."
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong>님이 <strong>%2</strong>에서 나를 언급했습니다."
3
3
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> paminėjo Jus <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> paminėjo Jus <strong>%2</strong>"
3
3
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> sebut anda di <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> sebut anda di <strong>%2</strong>"
3
3
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "Onze naam is genoemd door <strong>%1</strong> in <strong>%2</strong>."
1
+ {
2
+ "user_mentioned_you_in": "Onze naam is genoemd door <strong>%1</strong> in <strong>%2</strong>."
3
3
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> wspomniał o Tobie w <strong>%2</strong>"
3
- }
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> wspomniał o Tobie w <strong>%2</strong>"
3
+ }
@@ -1,6 +1,6 @@
1
- {
2
- "mentions": "Wspomnienia",
3
- "user_mentioned_you_in": "<strong>%1</strong> wspomniał o Tobie w <strong>%2</strong>",
4
- "user_mentioned_group_in": "<strong>%1</strong> wspomniał <strong>%2</strong> w <strong>%3</strong>",
5
- "notificationType_mention": "Kiedy ktoś o Tobie wspomni"
6
- }
1
+ {
2
+ "mentions": "Wspomnienia",
3
+ "user_mentioned_you_in": "<strong>%1</strong> wspomniał o Tobie w <strong>%2</strong>",
4
+ "user_mentioned_group_in": "<strong>%1</strong> wspomniał <strong>%2</strong> w <strong>%3</strong>",
5
+ "notificationType_mention": "Kiedy ktoś o Tobie wspomni"
6
+ }
@@ -1,6 +1,6 @@
1
- {
2
- "mentions": "Menções",
3
- "user_mentioned_you_in": "<strong>%1</strong> mencionou-te no tópico <strong>%2</strong>",
4
- "user_mentioned_group_in": "<strong>%1</strong> mencionou o grupo <strong>%2</strong> no tópico <strong>%3</strong>",
5
- "notificationType_mention": "Quando alguém te menciona"
6
- }
1
+ {
2
+ "mentions": "Menções",
3
+ "user_mentioned_you_in": "<strong>%1</strong> mencionou-te no tópico <strong>%2</strong>",
4
+ "user_mentioned_group_in": "<strong>%1</strong> mencionou o grupo <strong>%2</strong> no tópico <strong>%3</strong>",
5
+ "notificationType_mention": "Quando alguém te menciona"
6
+ }
@@ -1,4 +1,4 @@
1
- {
2
- "mentions": "Menções",
3
- "user_mentioned_you_in": "<strong>%1</strong> mencionou você em <strong>%2</strong>"
1
+ {
2
+ "mentions": "Menções",
3
+ "user_mentioned_you_in": "<strong>%1</strong> mencionou você em <strong>%2</strong>"
4
4
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> te-a menționat în <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> te-a menționat în <strong>%2</strong>"
3
3
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> yakuvuze muri <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> yakuvuze muri <strong>%2</strong>"
3
3
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> te je omenil v <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> te je omenil v <strong>%2</strong>"
3
3
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> вас помену у <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> вас помену у <strong>%2</strong>"
3
3
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> nämnde dig i <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> nämnde dig i <strong>%2</strong>"
3
3
  }
@@ -1,6 +1,6 @@
1
- {
2
- "mentions": "Bahsedilmeler",
3
- "user_mentioned_you_in": "<strong>%1</strong> sizden şu konuda bahsetti: <strong>%2</strong>",
4
- "user_mentioned_group_in": "<strong>%1</strong> kullanıcısı <strong>%2</strong> grubundan şu konuda bahsetti: <strong>%3</strong>",
5
- "notificationType_mention": "Biri sizden bahsettiğinde"
6
- }
1
+ {
2
+ "mentions": "Bahsedilmeler",
3
+ "user_mentioned_you_in": "<strong>%1</strong> sizden şu konuda bahsetti: <strong>%2</strong>",
4
+ "user_mentioned_group_in": "<strong>%1</strong> kullanıcısı <strong>%2</strong> grubundan şu konuda bahsetti: <strong>%3</strong>",
5
+ "notificationType_mention": "Biri sizden bahsettiğinde"
6
+ }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> nhắc đến bạn trong <strong>%2</strong>"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> nhắc đến bạn trong <strong>%2</strong>"
3
3
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> 在 <strong>%2</strong> 中提到了您"
3
- }
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> 在 <strong>%2</strong> 中提到了您"
3
+ }
@@ -1,6 +1,6 @@
1
- {
2
- "mentions": "提到",
3
- "user_mentioned_you_in": "<strong>%1</strong> 在 <strong>%2</strong> 中提到了你",
4
- "user_mentioned_group_in": "<strong>%1</strong> 在 <strong>%3</strong> 中提到了 <strong>%2</strong>",
5
- "notificationType_mention": "当有人提到你时"
1
+ {
2
+ "mentions": "提到",
3
+ "user_mentioned_you_in": "<strong>%1</strong> 在 <strong>%2</strong> 中提到了你",
4
+ "user_mentioned_group_in": "<strong>%1</strong> 在 <strong>%3</strong> 中提到了 <strong>%2</strong>",
5
+ "notificationType_mention": "当有人提到你时"
6
6
  }
@@ -1,3 +1,3 @@
1
- {
2
- "user_mentioned_you_in": "<strong>%1</strong> 在 <strong>%2</strong>提到你"
1
+ {
2
+ "user_mentioned_you_in": "<strong>%1</strong> 在 <strong>%2</strong>提到你"
3
3
  }
package/library.js CHANGED
@@ -27,7 +27,12 @@ const SocketPlugins = require.main.require('./src/socket.io/plugins');
27
27
 
28
28
  const utility = require('./lib/utility');
29
29
 
30
- const regex = XRegExp('(?:^|\\s|\\>|;)(@[\\p{L}\\d\\-_.]+)', 'g');
30
+ const parts = {
31
+ before: '(?:(^|\\p{^L}))', // a single unicode non-letter character or start of line
32
+ main: '(@[\\p{L}\\d\\-_.]+)', // unicode letters, numbers, dashes, underscores, or periods
33
+ after: '((?=\\b)(?=[^-])|$)', // used to figure out where latin mentions end
34
+ };
35
+ const regex = XRegExp(`${parts.before}${parts.main}`, 'g');
31
36
  const isLatinMention = /@[\w\d\-_.]+$/;
32
37
 
33
38
  const Mentions = module.exports;
@@ -293,8 +298,8 @@ Mentions.parseRaw = async (content) => {
293
298
 
294
299
  if (results.user.uid || results.groupExists) {
295
300
  const regex = isLatinMention.test(match) ?
296
- new RegExp(`(?:^|\\s|>|;)${match}((?=\\b)(?=[^-])|$)`, 'g') :
297
- new RegExp(`(?:^|\\s|>|;)${match}`, 'g');
301
+ XRegExp(`${parts.before}${match}${parts.after}`, 'g') :
302
+ XRegExp(`${parts.before}${match}`, 'g');
298
303
 
299
304
  let skip = false;
300
305
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nodebb-plugin-mentions",
3
- "version": "4.0.6",
3
+ "version": "4.1.1",
4
4
  "description": "NodeBB Plugin that allows users to mention other users by prepending an '@' sign to their username",
5
5
  "main": "library.js",
6
6
  "scripts": {
@@ -32,7 +32,7 @@
32
32
  },
33
33
  "devDependencies": {
34
34
  "mocha": "10.2.0",
35
- "eslint": "8.37.0",
35
+ "eslint": "8.39.0",
36
36
  "eslint-config-nodebb": "0.2.1",
37
37
  "eslint-plugin-import": "2.27.5"
38
38
  }
package/plugin.json CHANGED
@@ -1,31 +1,31 @@
1
- {
2
- "id": "nodebb-plugin-mentions",
3
- "name": "Username Mentions",
4
- "description": "NodeBB Plugin that allows users to mention other users by prepending an '@' sign to their username",
5
- "url": "https://github.com/julianlam/nodebb-plugin-mentions",
6
- "library": "./library.js",
7
- "upgrades": [
8
- "upgrades/mentions_delete_mentions_set_zset.js"
9
- ],
10
- "hooks": [
11
- { "hook": "static:app.load", "method": "init" },
12
- { "hook": "filter:admin.header.build", "method": "addAdminNavigation" },
13
- { "hook": "filter:parse.post", "method": "parsePost" },
14
- { "hook": "filter:parse.raw", "method": "parseRaw" },
15
- { "hook": "action:post.save", "method": "notify" },
16
- { "hook": "action:post.edit", "method": "notify" },
17
- { "hook": "action:posts.purge", "method": "actionPostsPurge" },
18
- { "hook": "filter:notifications.addFilters", "method": "addFilters" },
19
- { "hook": "filter:user.notificationTypes", "method": "notificationTypes" },
20
- { "hook": "filter:users.addFields", "method": "addFields" }
21
- ],
22
- "scripts": [
23
- "static/autofill.js"
24
- ],
25
- "modules": {
26
- "../admin/plugins/mentions.js": "./static/admin.js"
27
- },
28
- "languages": "languages",
29
- "defaultLang": "en_GB",
30
- "templates": "templates"
1
+ {
2
+ "id": "nodebb-plugin-mentions",
3
+ "name": "Username Mentions",
4
+ "description": "NodeBB Plugin that allows users to mention other users by prepending an '@' sign to their username",
5
+ "url": "https://github.com/julianlam/nodebb-plugin-mentions",
6
+ "library": "./library.js",
7
+ "upgrades": [
8
+ "upgrades/mentions_delete_mentions_set_zset.js"
9
+ ],
10
+ "hooks": [
11
+ { "hook": "static:app.load", "method": "init" },
12
+ { "hook": "filter:admin.header.build", "method": "addAdminNavigation" },
13
+ { "hook": "filter:parse.post", "method": "parsePost" },
14
+ { "hook": "filter:parse.raw", "method": "parseRaw" },
15
+ { "hook": "action:post.save", "method": "notify" },
16
+ { "hook": "action:post.edit", "method": "notify" },
17
+ { "hook": "action:posts.purge", "method": "actionPostsPurge" },
18
+ { "hook": "filter:notifications.addFilters", "method": "addFilters" },
19
+ { "hook": "filter:user.notificationTypes", "method": "notificationTypes" },
20
+ { "hook": "filter:users.addFields", "method": "addFields" }
21
+ ],
22
+ "scripts": [
23
+ "static/autofill.js"
24
+ ],
25
+ "modules": {
26
+ "../admin/plugins/mentions.js": "./static/admin.js"
27
+ },
28
+ "languages": "languages",
29
+ "defaultLang": "en_GB",
30
+ "templates": "templates"
31
31
  }
package/static/.eslintrc CHANGED
@@ -1,3 +1,3 @@
1
- {
2
- "extends": "nodebb/public"
3
- }
1
+ {
2
+ "extends": "nodebb/public"
3
+ }
package/test/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- /* globals describe, it, before */
3
+ /* globals describe, it, beforeEach */
4
4
 
5
5
  const assert = require('assert');
6
6
 
@@ -16,23 +16,28 @@ const regex = main._regex;
16
16
  // use core slugify module
17
17
  const slugify = require.main.require('./src/slugify');
18
18
 
19
+ const strings = [
20
+ '@testUser',
21
+ '@testUser some text',
22
+ 'some text @testUser',
23
+ '<a href="/user/testuser">@testUser</a>',
24
+ '<a href="/user/testuser">@testUser</a> some text',
25
+ 'some text <a href="/user/testuser">@testUser</a>',
26
+ 'end of sentence. @testUser',
27
+ '@testUser.',
28
+ '@testUser\'s some text',
29
+ '> @testUser blockquoted',
30
+ '(@testUser) bracketed',
31
+ 'elon makes me think of this emoji: 💩@testUser',
32
+ ];
33
+
19
34
  describe('regex', () => {
20
35
  const matcher = new RegExp(regex);
21
- const strings = [
22
- '@testUser',
23
- '@testUser some text',
24
- 'some text @testUser',
25
- '<a href="/user/testuser">@testUser</a>',
26
- '<a href="/user/testuser">@testUser</a> some text',
27
- 'some text <a href="/user/testuser">@testUser</a>',
28
- 'end of sentence. @testUser',
29
- '@testUser.',
30
- '@testUser\'s some text',
31
- ];
32
- it('should match a mention in all strings', () => {
33
- strings.forEach((string) => {
36
+
37
+ strings.forEach((string) => {
38
+ it('should match a mention in all test strings', () => {
34
39
  const matches = string.match(matcher);
35
- assert(matches);
40
+ assert(matches, `@testUser was not found in this string: ${string}`);
36
41
  assert.equal(slugify(matches[0]), 'testuser');
37
42
  });
38
43
  });
@@ -152,19 +157,35 @@ describe('splitter', () => {
152
157
 
153
158
  describe('parser', () => {
154
159
  let slug;
160
+ let uid;
155
161
 
156
- before(async () => {
162
+ beforeEach(async () => {
157
163
  slug = utils.generateUUID().slice(0, 10);
158
- await Promise.all([slug, `${slug}-two`].map(async (username) => {
159
- await user.create({ username });
160
- }));
164
+ uid = await user.create({ username: slug });
161
165
  });
162
166
 
163
167
  it('should properly parse both users even if one user\'s username is a subset of the other', async () => {
168
+ await user.create({ username: `${slug}-two` });
164
169
  const md = `This sentence contains two mentions: @${slug} and @${slug}-two`;
165
170
 
166
171
  const html = await main.parseRaw(md);
167
172
 
168
173
  assert.strictEqual(html, `This sentence contains two mentions: <a class="plugin-mentions-user plugin-mentions-a" href="http://127.0.0.1:4567/uid/1">@${slug}</a> and <a class="plugin-mentions-user plugin-mentions-a" href="http://127.0.0.1:4567/uid/2">@${slug}-two</a>`);
169
174
  });
175
+
176
+ strings.forEach((string) => {
177
+ it('should match correctly replace the mentions in all test strings', async () => {
178
+ const index = string.indexOf('@testUser');
179
+ let check = string;
180
+ if (!index || string[index - 1] !== '>') {
181
+ check = string.replace(/@testUser/g, `<a class="plugin-mentions-user plugin-mentions-a" href="http://127.0.0.1:4567/uid/${uid}">@${slug}</a>`);
182
+ string = string.replace(/testUser/g, slug);
183
+ }
184
+ const html = await main.parseRaw(string);
185
+
186
+ assert(html);
187
+
188
+ assert.strictEqual(html, check);
189
+ });
190
+ });
170
191
  });