FIX: Ensure mention autocomplete box doesn't go off-screen in RTL locales (#21905)
Meta topic: https://meta.discourse.org/t/mention-suggestion-list-box-in-the-rtl-website-in-wrong-place/266763?u=osama. Our autocomplete box doesn't currently take into account the user's locale and places itself off-screen when using an RTL locale. This commit changes the placement logic for the autocomplete box when an RTL locale is used to make sure that: 1. the autocomplete box's right side is near and to the left of the caret 2. the autocomplete box doesn't go beyond the composer's left side.
This commit is contained in:
parent
95a51b7d8a
commit
fc0e7fe802
|
@ -6,6 +6,7 @@ import Site from "discourse/models/site";
|
||||||
import { createPopper } from "@popperjs/core";
|
import { createPopper } from "@popperjs/core";
|
||||||
import discourseDebounce from "discourse-common/lib/debounce";
|
import discourseDebounce from "discourse-common/lib/debounce";
|
||||||
import { iconHTML } from "discourse-common/lib/icon-library";
|
import { iconHTML } from "discourse-common/lib/icon-library";
|
||||||
|
import { isDocumentRTL } from "discourse/lib/text-direction";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This is a jQuery plugin to support autocompleting values in our text fields.
|
This is a jQuery plugin to support autocompleting values in our text fields.
|
||||||
|
@ -420,20 +421,14 @@ export default function (options) {
|
||||||
}
|
}
|
||||||
|
|
||||||
let vOffset = 0;
|
let vOffset = 0;
|
||||||
let hOffset = 0;
|
|
||||||
let pos = me.caretPosition({
|
let pos = me.caretPosition({
|
||||||
pos: completeStart + 1,
|
pos: completeStart + 1,
|
||||||
});
|
});
|
||||||
|
|
||||||
hOffset = 10;
|
|
||||||
if (options.treatAsTextarea) {
|
if (options.treatAsTextarea) {
|
||||||
vOffset = -32;
|
vOffset = -32;
|
||||||
}
|
}
|
||||||
|
|
||||||
div.css({
|
|
||||||
left: "-1000px",
|
|
||||||
});
|
|
||||||
|
|
||||||
if (!isInput && !options.treatAsTextarea) {
|
if (!isInput && !options.treatAsTextarea) {
|
||||||
vOffset = div.height();
|
vOffset = div.height();
|
||||||
|
|
||||||
|
@ -446,34 +441,39 @@ export default function (options) {
|
||||||
vOffset = BELOW;
|
vOffset = BELOW;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (Site.currentProp("mobileView") && me.height() / 2 >= pos.top) {
|
||||||
|
vOffset = BELOW;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const mePos = me.position();
|
||||||
|
|
||||||
|
let left;
|
||||||
|
if (isDocumentRTL()) {
|
||||||
|
left = mePos.left + pos.left - div.width();
|
||||||
|
} else {
|
||||||
|
let hOffset = 10;
|
||||||
if (Site.currentProp("mobileView")) {
|
if (Site.currentProp("mobileView")) {
|
||||||
if (me.height() / 2 >= pos.top) {
|
|
||||||
vOffset = BELOW;
|
|
||||||
}
|
|
||||||
if (me.width() / 2 <= pos.left) {
|
if (me.width() / 2 <= pos.left) {
|
||||||
hOffset = -div.width();
|
hOffset = -div.width();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
left = mePos.left + pos.left + hOffset;
|
||||||
}
|
}
|
||||||
|
|
||||||
let mePos = me.position();
|
|
||||||
|
|
||||||
let borderTop = parseInt(me.css("border-top-width"), 10) || 0;
|
|
||||||
|
|
||||||
let left = mePos.left + pos.left + hOffset;
|
|
||||||
if (left < 0) {
|
if (left < 0) {
|
||||||
left = 0;
|
left = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
const offsetTop = me.offset().top;
|
const offsetTop = me.offset().top;
|
||||||
|
const borderTop = parseInt(me.css("border-top-width"), 10) || 0;
|
||||||
if (mePos.top + pos.top + borderTop - vOffset + offsetTop < 30) {
|
if (mePos.top + pos.top + borderTop - vOffset + offsetTop < 30) {
|
||||||
vOffset = BELOW;
|
vOffset = BELOW;
|
||||||
}
|
}
|
||||||
|
|
||||||
div.css({
|
div.css({
|
||||||
position: "absolute",
|
position: "absolute",
|
||||||
top: mePos.top + pos.top - vOffset + borderTop + "px",
|
top: `${mePos.top + pos.top - vOffset + borderTop}px`,
|
||||||
left: left + "px",
|
left: `${left}px`,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue