FIX: chat height fixes (#21561)
- Correctly resize when sending a message on android - Do not blur active element - Update direct message creator height following changes
This commit is contained in:
parent
4bc769cac0
commit
a3522a5937
|
@ -15,7 +15,8 @@ export default class ChatVh extends Component {
|
||||||
this._super(...arguments);
|
this._super(...arguments);
|
||||||
|
|
||||||
if ("virtualKeyboard" in navigator) {
|
if ("virtualKeyboard" in navigator) {
|
||||||
navigator.virtualKeyboard.overlaysContent = false;
|
navigator.virtualKeyboard.overlaysContent = true;
|
||||||
|
navigator.virtualKeyboard.addEventListener("geometrychange", this.setVH);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.activeWindow = window.visualViewport || window;
|
this.activeWindow = window.visualViewport || window;
|
||||||
|
@ -28,6 +29,13 @@ export default class ChatVh extends Component {
|
||||||
|
|
||||||
this.activeWindow?.removeEventListener("resize", this.setVH);
|
this.activeWindow?.removeEventListener("resize", this.setVH);
|
||||||
lastVH = null;
|
lastVH = null;
|
||||||
|
|
||||||
|
if ("virtualKeyboard" in navigator) {
|
||||||
|
navigator.virtualKeyboard.removeEventListener(
|
||||||
|
"geometrychange",
|
||||||
|
this.setVH
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@bind
|
@bind
|
||||||
|
@ -36,14 +44,20 @@ export default class ChatVh extends Component {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const vh = (this.activeWindow?.height || window.innerHeight) * 0.01;
|
let height;
|
||||||
|
if ("virtualKeyboard" in navigator) {
|
||||||
|
height =
|
||||||
|
window.visualViewport.height -
|
||||||
|
navigator.virtualKeyboard.boundingRect.height;
|
||||||
|
} else {
|
||||||
|
height = this.activeWindow?.height || window.innerHeight;
|
||||||
|
}
|
||||||
|
|
||||||
|
const vh = height * 0.01;
|
||||||
|
|
||||||
if (lastVH === vh) {
|
if (lastVH === vh) {
|
||||||
return;
|
return;
|
||||||
} else if (this.capabilities.touch && lastVH < vh && vh - lastVH > 1) {
|
|
||||||
this.#blurActiveElement();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
lastVH = vh;
|
lastVH = vh;
|
||||||
|
|
||||||
document.documentElement.style.setProperty(CSS_VAR, `${vh}px`);
|
document.documentElement.style.setProperty(CSS_VAR, `${vh}px`);
|
||||||
|
|
|
@ -9,6 +9,8 @@
|
||||||
class="direct-message-creator"
|
class="direct-message-creator"
|
||||||
{{did-insert this.setDirectMessageCreatorHeight}}
|
{{did-insert this.setDirectMessageCreatorHeight}}
|
||||||
{{will-destroy this.unsetDirectMessageCreatorHeight}}
|
{{will-destroy this.unsetDirectMessageCreatorHeight}}
|
||||||
|
{{did-update this.setDirectMessageCreatorHeight this.selectedUsers}}
|
||||||
|
{{did-update this.setDirectMessageCreatorHeight this.users}}
|
||||||
>
|
>
|
||||||
<div
|
<div
|
||||||
class="filter-area {{if this.isFilterFocused 'is-focused'}}"
|
class="filter-area {{if this.isFilterFocused 'is-focused'}}"
|
||||||
|
|
|
@ -8,6 +8,14 @@ $float-height: 530px;
|
||||||
--chat-header-offset: 50px;
|
--chat-header-offset: 50px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Very specific hack to ensure the contextual menu (copy/paste/...) is
|
||||||
|
// not completly over the textarea, the rules to position this menu are quite obscure
|
||||||
|
// and under DiscourseHUB the space between the textarea and the keyboard is so small that
|
||||||
|
// it sometimes prefer to appear on top of the textarea, making any gesture very complicated
|
||||||
|
html.ios-device.keyboard-visible body #main-outlet .full-page-chat {
|
||||||
|
padding-bottom: 0.2rem;
|
||||||
|
}
|
||||||
|
|
||||||
.chat-message-move-to-channel-modal-modal {
|
.chat-message-move-to-channel-modal-modal {
|
||||||
.modal-inner-container {
|
.modal-inner-container {
|
||||||
.chat-move-message-channel-chooser {
|
.chat-move-message-channel-chooser {
|
||||||
|
|
Loading…
Reference in New Issue