DEV: Improve header offset calculation (#24910)
This commit is contained in:
parent
437c2c5552
commit
8a4ab79be2
|
@ -448,27 +448,37 @@ export default SiteHeaderComponent.extend({
|
|||
|
||||
@bind
|
||||
updateHeaderOffset() {
|
||||
let headerWrapTop = this.headerWrap.getBoundingClientRect().top;
|
||||
// Safari likes overscolling the page (on both iOS and macOS).
|
||||
// This shows up as a negative value in window.scrollY.
|
||||
// We can use this to offset the headerWrap's top offset to avoid
|
||||
// jitteriness and bad positioning.
|
||||
const windowOverscroll = Math.min(0, window.scrollY);
|
||||
|
||||
if (headerWrapTop !== 0) {
|
||||
headerWrapTop -= Math.max(0, document.body.getBoundingClientRect().top);
|
||||
}
|
||||
// The headerWrap's top offset can also be a negative value on Safari,
|
||||
// because of the changing height of the viewport (due to the URL bar).
|
||||
// For our use case, it's best to ensure this is clamped to 0.
|
||||
const headerWrapTop = Math.max(
|
||||
0,
|
||||
Math.floor(this.headerWrap.getBoundingClientRect().top)
|
||||
);
|
||||
let offsetTop = headerWrapTop + windowOverscroll;
|
||||
|
||||
if (DEBUG && isTesting()) {
|
||||
headerWrapTop -= document
|
||||
offsetTop -= document
|
||||
.getElementById("ember-testing-container")
|
||||
.getBoundingClientRect().top;
|
||||
|
||||
headerWrapTop -= 1; // For 1px border on testing container
|
||||
offsetTop -= 1; // For 1px border on testing container
|
||||
}
|
||||
|
||||
const documentStyle = document.documentElement.style;
|
||||
|
||||
const currentValue = documentStyle.getPropertyValue("--header-offset");
|
||||
const newValue = `${this.headerWrap.offsetHeight + headerWrapTop}px`;
|
||||
const currentValue =
|
||||
parseInt(documentStyle.getPropertyValue("--header-offset"), 10) || 0;
|
||||
const newValue = this.headerWrap.offsetHeight + offsetTop;
|
||||
|
||||
if (currentValue !== newValue) {
|
||||
documentStyle.setProperty("--header-offset", newValue);
|
||||
documentStyle.setProperty("--header-offset", `${newValue}px`);
|
||||
}
|
||||
},
|
||||
|
||||
|
|
|
@ -1,18 +1,12 @@
|
|||
import Component from "@glimmer/component";
|
||||
import { action } from "@ember/object";
|
||||
import { inject as service } from "@ember/service";
|
||||
import { htmlSafe } from "@ember/template";
|
||||
import DButton from "discourse/components/d-button";
|
||||
import { headerOffset } from "discourse/lib/offset-calculator";
|
||||
import DiscourseURL from "discourse/lib/url";
|
||||
|
||||
export default class ChatNavbar extends Component {
|
||||
@service chatStateManager;
|
||||
|
||||
get topStyle() {
|
||||
return htmlSafe(`top: ${headerOffset()}px`);
|
||||
}
|
||||
|
||||
@action
|
||||
async closeFullScreen() {
|
||||
this.chatStateManager.prefersDrawer();
|
||||
|
@ -26,7 +20,7 @@ export default class ChatNavbar extends Component {
|
|||
}
|
||||
|
||||
<template>
|
||||
<div class="chat-navbar-container" style={{this.topStyle}}>
|
||||
<div class="chat-navbar-container">
|
||||
<nav class="chat-navbar">
|
||||
{{#if (has-block "current")}}
|
||||
<span class="chat-navbar__current">
|
||||
|
|
|
@ -9,6 +9,7 @@
|
|||
position: sticky;
|
||||
border-bottom: 1px solid var(--primary-low);
|
||||
background: var(--secondary);
|
||||
top: var(--header-offset);
|
||||
height: 50px;
|
||||
box-sizing: border-box;
|
||||
display: flex;
|
||||
|
|
Loading…
Reference in New Issue