FIX: Ensure hashtag autocomplete is not behind keyboard in chat (#19419)

We must set `treatAsTextarea` to true when using autocomplete
in the chat composer, since it is at the bottom of the screen
we always want to show it above the composer. This fixes the
issue where the hashtag autocomplete results went behind the
keyboard on mobile (which was not happening for mentions).
This commit is contained in:
Martin Brennan 2022-12-12 15:14:51 +10:00 committed by GitHub
parent b6340c0d74
commit 735e96e5a0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 26 additions and 13 deletions

View File

@ -464,9 +464,11 @@ export default Component.extend(TextareaTextManipulation, {
this.site.hashtag_configurations["topic-composer"], this.site.hashtag_configurations["topic-composer"],
this._$textarea, this._$textarea,
this.siteSettings, this.siteSettings,
(value) => { {
this.set("value", value); afterComplete: (value) => {
schedule("afterRender", this, this.focusTextArea); this.set("value", value);
schedule("afterRender", this, this.focusTextArea);
},
} }
); );
}, },

View File

@ -27,23 +27,30 @@ import { htmlSafe } from "@ember/template";
* @param {$Element} $textarea - jQuery element to use for the autocompletion * @param {$Element} $textarea - jQuery element to use for the autocompletion
* plugin to attach to, this is what will watch for the # matcher when the user is typing. * plugin to attach to, this is what will watch for the # matcher when the user is typing.
* @param {Hash} siteSettings - The clientside site settings. * @param {Hash} siteSettings - The clientside site settings.
* @param {Function} afterComplete - Called with the selected autocomplete option once it is selected. * @param {Function} autocompleteOptions - Options to pass to the jQuery plugin. Must at least include:
*
* - afterComplete - Called with the selected autocomplete option once it is selected.
*
* Can also include:
*
* - treatAsTextarea - Whether to anchor the autocompletion to the start of the input and
* ensure the popper is always on top.
**/ **/
export function setupHashtagAutocomplete( export function setupHashtagAutocomplete(
contextualHashtagConfiguration, contextualHashtagConfiguration,
$textArea, $textArea,
siteSettings, siteSettings,
afterComplete autocompleteOptions = {}
) { ) {
if (siteSettings.enable_experimental_hashtag_autocomplete) { if (siteSettings.enable_experimental_hashtag_autocomplete) {
_setupExperimental( _setupExperimental(
contextualHashtagConfiguration, contextualHashtagConfiguration,
$textArea, $textArea,
siteSettings, siteSettings,
afterComplete autocompleteOptions
); );
} else { } else {
_setup($textArea, siteSettings, afterComplete); _setup($textArea, siteSettings, autocompleteOptions.afterComplete);
} }
} }
@ -123,13 +130,14 @@ function _setupExperimental(
contextualHashtagConfiguration, contextualHashtagConfiguration,
$textArea, $textArea,
siteSettings, siteSettings,
afterComplete autocompleteOptions
) { ) {
$textArea.autocomplete({ $textArea.autocomplete({
template: findRawTemplate("hashtag-autocomplete"), template: findRawTemplate("hashtag-autocomplete"),
key: "#", key: "#",
afterComplete, afterComplete: autocompleteOptions.afterComplete,
treatAsTextarea: $textArea[0].tagName === "INPUT", treatAsTextarea: autocompleteOptions.treatAsTextarea,
autoSelectFirstSuggestion: true,
transformComplete: (obj) => obj.ref, transformComplete: (obj) => obj.ref,
dataSource: (term) => { dataSource: (term) => {
if (term.match(/\s/)) { if (term.match(/\s/)) {

View File

@ -410,9 +410,12 @@ export default Component.extend(TextareaTextManipulation, {
this.site.hashtag_configurations["chat-composer"], this.site.hashtag_configurations["chat-composer"],
$textarea, $textarea,
this.siteSettings, this.siteSettings,
(value) => { {
this.set("value", value); treatAsTextarea: true,
return this._focusTextArea(); afterComplete: (value) => {
this.set("value", value);
return this._focusTextArea();
},
} }
); );
}, },