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:
parent
b6340c0d74
commit
735e96e5a0
|
@ -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) => {
|
{
|
||||||
|
afterComplete: (value) => {
|
||||||
this.set("value", value);
|
this.set("value", value);
|
||||||
schedule("afterRender", this, this.focusTextArea);
|
schedule("afterRender", this, this.focusTextArea);
|
||||||
|
},
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
|
|
|
@ -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/)) {
|
||||||
|
|
|
@ -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) => {
|
{
|
||||||
|
treatAsTextarea: true,
|
||||||
|
afterComplete: (value) => {
|
||||||
this.set("value", value);
|
this.set("value", value);
|
||||||
return this._focusTextArea();
|
return this._focusTextArea();
|
||||||
|
},
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue