-
Notifications
You must be signed in to change notification settings - Fork 3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix: Chat - App closes mention suggestions when cursor is between double @ #29239
Changes from 2 commits
fd994ae
9013b09
b3804d3
d7ec776
64df898
f78bc4c
3c5a381
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -1265,6 +1265,8 @@ const CONST = { | |
CARD_EXPIRATION_DATE: /^(0[1-9]|1[0-2])([^0-9])?([0-9]{4}|([0-9]{2}))$/, | ||
ROOM_NAME: /^#[\p{Ll}0-9-]{1,80}$/u, | ||
|
||
// eslint-disable-next-line max-len, no-misleading-character-class | ||
EMOJI: /[\p{Extended_Pictographic}\u200d\u{1f1e6}-\u{1f1ff}\u{1f3fb}-\u{1f3ff}\u{e0020}-\u{e007f}\u20E3\uFE0F]|[#*0-9]\uFE0F?\u20E3/gu, | ||
// eslint-disable-next-line max-len, no-misleading-character-class | ||
EMOJIS: /[\p{Extended_Pictographic}](\u200D[\p{Extended_Pictographic}]|[\u{1F3FB}-\u{1F3FF}]|[\u{E0020}-\u{E007F}]|\uFE0F|\u20E3)*|[\u{1F1E6}-\u{1F1FF}]{2}|[#*0-9]\uFE0F?\u20E3/gu, | ||
|
||
|
@@ -1283,18 +1285,26 @@ const CONST = { | |
HAS_COLON_ONLY_AT_THE_BEGINNING: /^:[^:]+$/, | ||
HAS_AT_MOST_TWO_AT_SIGNS: /^@[^@]*@?[^@]*$/, | ||
|
||
SPECIAL_CHAR_OR_EMOJI: | ||
// eslint-disable-next-line no-misleading-character-class | ||
/[\n\s,/?"{}[\]()&_~^%\\;`$=#<>!*\p{Extended_Pictographic}\u200d\u{1f1e6}-\u{1f1ff}\u{1f3fb}-\u{1f3ff}\u{e0020}-\u{e007f}\u20E3\uFE0F]|[#*0-9]\uFE0F?\u20E3/gu, | ||
SPECIAL_CHAR: /[,/?"{}[\]()&^%;`$=#<>!*]/g, | ||
|
||
get SPECIAL_CHAR_OR_EMOJI() { | ||
return new RegExp(`[_~\\n\\s]|${this.SPECIAL_CHAR.source}|${this.EMOJI.source}`, 'gu'); | ||
}, | ||
|
||
SPACE_OR_EMOJI: | ||
// eslint-disable-next-line no-misleading-character-class | ||
/(\s+|(?:[\p{Extended_Pictographic}\u200d\u{1f1e6}-\u{1f1ff}\u{1f3fb}-\u{1f3ff}\u{e0020}-\u{e007f}\u20E3\uFE0F]|[#*0-9]\uFE0F?\u20E3)+)/gu, | ||
get SPACE_OR_EMOJI() { | ||
return new RegExp(`(\\s+|(?:${this.EMOJI.source})+)`, 'gu'); | ||
}, | ||
|
||
// Define the regular expression pattern to find a potential end of a mention suggestion: | ||
// It might be a space, a newline character, an emoji, or a special character (excluding underscores, which might be used in usernames) | ||
paultsimura marked this conversation as resolved.
Show resolved
Hide resolved
|
||
get MENTION_BREAKER() { | ||
return new RegExp(`[\\n\\s]|${this.SPECIAL_CHAR.source}|${this.EMOJI.source}`, 'gu'); | ||
}, | ||
|
||
// Define the regular expression pattern to match a string starting with an at sign and ending with a space or newline character | ||
MENTION_REPLACER: | ||
// eslint-disable-next-line no-misleading-character-class | ||
/^@[^\n\r]*?(?=$|[\s,/?"{}[\]()&^%\\;`$=#<>!*\p{Extended_Pictographic}\u200d\u{1f1e6}-\u{1f1ff}\u{1f3fb}-\u{1f3ff}\u{e0020}-\u{e007f}\u20E3\uFE0F]|[#*0-9]\uFE0F?\u20E3)/u, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As we changed the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @parasharrajat I don't see how Also, we did not change the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Oh, my bad. This is sleep, talking. Please ignore. |
||
get MENTION_REPLACER() { | ||
return new RegExp(`^@[^\\n\\r]*?(?=$|\\s|${this.SPECIAL_CHAR.source}|${this.EMOJI.source})`, 'u'); | ||
}, | ||
|
||
MERGED_ACCOUNT_PREFIX: /^(MERGED_\d+@)/, | ||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -188,17 +188,12 @@ function SuggestionMention({ | |
} | ||
|
||
const valueAfterTheCursor = value.substring(selectionEnd); | ||
const indexOfFirstWhitespaceCharOrEmojiAfterTheCursor = valueAfterTheCursor.search(CONST.REGEX.NEW_LINE_OR_WHITE_SPACE_OR_EMOJI); | ||
|
||
let indexOfLastNonWhitespaceCharAfterTheCursor; | ||
if (indexOfFirstWhitespaceCharOrEmojiAfterTheCursor === -1) { | ||
// we didn't find a whitespace/emoji after the cursor, so we will use the entire string | ||
indexOfLastNonWhitespaceCharAfterTheCursor = value.length; | ||
} else { | ||
indexOfLastNonWhitespaceCharAfterTheCursor = indexOfFirstWhitespaceCharOrEmojiAfterTheCursor + selectionEnd; | ||
} | ||
// Breaking symbol is a space, a special char, or an emoji | ||
const suggestionBreakerRelativeIndex = valueAfterTheCursor.search(CONST.REGEX.MENTION_BREAKER); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. let's use a better name. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Ok, reverted to the same format as before to minimize my changes. |
||
// If a breaking symbol after the cursor is not found, use the entire string | ||
const suggestionEndIndex = suggestionBreakerRelativeIndex === -1 ? value.length : suggestionBreakerRelativeIndex + selectionEnd; | ||
|
||
const leftString = value.substring(0, indexOfLastNonWhitespaceCharAfterTheCursor); | ||
const leftString = value.substring(0, suggestionEndIndex); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This caused a regression when pressing the left/right arrow keys after typing '@', the text selection does not move, #39102 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @eh2077 I think you should keep digging – this is not the correct PR for the mentioned issue. This one was released half a year ago, and your issue is quite fresh (it wasn't even happening in production). There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hi @paultsimura, thanks for your comment. I commented here to complete the checklist (the one before closing out an issue), so the linked issue has been fixed in production. I believe that issue was introduced after this PR. Can you take a look at your recording - There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. If you're talking about the selection (and the search term) not changing – it's the expected behavior: #29239 (comment) From what I see, your issue was about the cursor not moving, not the selection. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. That's unexpected behavior as we want highlighted text to be updated when moving cursor There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Did you get this confirmed with the internal team? At the time I implemented this PR, this was the expected behavior confirmed with the team. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. See #39102 (comment) |
||
const words = leftString.split(CONST.REGEX.SPACE_OR_EMOJI); | ||
const lastWord = _.last(words); | ||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
All of these are just refactors or something changed for this issue.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For this issue, I have introduced the
MENTION_BREAKER
RegExp – it differs a tiny bit from theSPECIAL_CHAR_OR_EMOJI
in my original proposal. It allows to use symbols_
and~
in the mention, as they might be present in usernames (especially the_
).All the rest is just refactoring.