Ya veo, esto lo soluciona:
diff --git a/frontend/discourse/app/modifiers/d-autocomplete.js b/frontend/discourse/app/modifiers/d-autocomplete.js
index e49fc0ec53..33fb51a1f4 100644
--- a/frontend/discourse/app/modifiers/d-autocomplete.js
+++ b/frontend/discourse/app/modifiers/d-autocomplete.js
@@ -599,10 +599,19 @@ export default class DAutocompleteModifier extends Modifier {
prev = this.getValue()[caretPos - 1];
const shouldTrigger = await this.shouldTrigger({ backSpace });
- if (
- shouldTrigger &&
- (prev === undefined || this.ALLOWED_LETTERS_REGEXP.test(prev))
- ) {
+ // Para el autocompletado de emojis (key === ':'), usa una comprobación más permisiva que incluya
+ // signos de puntuación comunes como coma, punto, etc. que pueden aparecer antes de los emojis.
+ let isAllowed;
+ if (this.options.key === ":") {
+ // Coincide con los mismos caracteres permitidos en la expresión regular onKeyUp del autocompletado de emojis
+ isAllowed =
+ prev === undefined || /[\\s.?,@/#!%\u0026*;:\\[\\]{}=\\-_()+]/.test(prev);
+ } else {
+ isAllowed =
+ prev === undefined || this.ALLOWED_LETTERS_REGEXP.test(prev);
+ }
+
+ if (shouldTrigger && isAllowed) {
start = caretPos;
term = this.getValue().substring(caretPos + 1, initialCaretPos);
end = caretPos + term.length;
@kelv No estoy muy familiarizado con cómo evolucionó este código, ¿quizás algo de esto te suena de alguna de las portabilidades que hiciste recientemente?