fix: position floating buttons relative to help button without wrapping it

(changing help button dom parent makes notion error when inserting elements relative to it)
This commit is contained in:
dragonwocky 2024-04-23 13:36:56 +10:00
parent 222d544f88
commit f0d7d89653
Signed by: dragonwocky
GPG Key ID: 7998D08F7D7BD7A8
6 changed files with 49 additions and 34 deletions

View File

@ -287,7 +287,6 @@ const _tokens = new Set(),
if (_stylesheet.innerHTML !== res.css) _stylesheet.innerHTML = res.css;
};
addMutationListener("*", (mutation) => {
const targets = [];
if (mutation.type === "childList") {
for (const node of mutation.addedNodes) extractTokens(node);
} else if (mutation.type === "attributes") extractTokens(mutation.target);

View File

@ -9,19 +9,23 @@ const setupWrapper = () => {
const notionHelp = ".notion-help-button",
{ html, addMutationListener } = globalThis.__enhancerApi,
{ removeMutationListener } = globalThis.__enhancerApi;
return (__$wrapper ??= new Promise((res, rej) => {
return (__$wrapper ??= new Promise((res) => {
const addToDom = () => {
const $help = document.querySelector(notionHelp);
if (!$help) return;
const $wrapper = html`<div
class="notion-enhancer--floating-buttons z-50
absolute bottom-[calc(26px+env(safe-area-inset-bottom))]
flex gap-[12px] important:[&>.notion-help-button]:static"
style="right:${$help.style.right}"
></div>`;
const gap = 12,
computedStyles = getComputedStyle($help),
visible = computedStyles.getPropertyValue("display") !== "none",
width = computedStyles.getPropertyValue("width"),
right = computedStyles.getPropertyValue("right"),
offset = visible ? parseInt(width) + parseInt(right) + gap : 26,
$wrapper = html`<div
class="notion-enhancer--floating-buttons z-50 gap-[${gap}px]
flex absolute bottom-[calc(26px+env(safe-area-inset-bottom))]"
style="right:${offset}px"
></div>`;
removeMutationListener(addToDom);
$help.replaceWith($wrapper);
$wrapper.append($help);
$help.after($wrapper);
res($wrapper);
};
addMutationListener(notionHelp, addToDom);

View File

@ -303,22 +303,34 @@ function Panel({
// moves help button out of the way of open panel.
// normally would place outside of an island, but in
// this case is necessary for syncing up animations
const floatingButtons =
".notion-enhancer--floating-buttons, .notion-help-button",
repositionFloatingButtons = async (width) => {
const $floatingButtons = document.querySelector(floatingButtons);
if (!$floatingButtons) return;
width ??= await getWidth();
if (isNaN(width)) width = minWidth;
if (!isPinned()) width = 0;
const to = `${26 + width}px`,
from = $floatingButtons.style.getPropertyValue("right");
if (from === to) return;
$floatingButtons.style.setProperty("right", to);
animate($floatingButtons, [({ right: from }, { right: to })]);
removeMutationListener(repositionFloatingButtons);
const notionHelp = ".notion-help-button",
floatingButtons = ".notion-enhancer--floating-buttons",
repositionCorner = async (offset) => {
const $help = document.querySelector(notionHelp),
$floating = document.querySelector(floatingButtons);
offset ??= await getWidth();
if (isNaN(offset)) offset = minWidth;
if (!isPinned()) offset = 0;
// offset help from panel edge
offset += 26;
for (const $btn of [$help, $floating]) {
if (!$btn) continue;
const computedStyles = getComputedStyle($btn),
visible = computedStyles.getPropertyValue("display") !== "none";
if (!visible) continue;
const width = computedStyles.getPropertyValue("width"),
from = computedStyles.getPropertyValue("right"),
to = offset + "px";
// offset floating buttons from help
offset += 12 + parseInt(width);
if (from === to) continue;
$btn.style.setProperty("right", to);
animate($btn, [({ right: from }, { right: to })]);
}
if ($help || $floating) removeMutationListener(repositionCorner);
};
addMutationListener(floatingButtons, repositionFloatingButtons);
const corner = `${notionHelp}, ${floatingButtons}`;
addMutationListener(corner, repositionCorner, { subtree: false });
$panel.pin = () => {
if (isPinned() || !panelViews.length) return;
@ -380,7 +392,7 @@ function Panel({
const $parent = $panel.parentElement || $panel;
$parent.style.setProperty("--panel--width", `${width}px`);
if ($parent !== $panel) $panel.style.removeProperty("--panel--width");
repositionFloatingButtons(width);
repositionCorner(width);
};
useState(["panelViews"], async ([panelViews = []]) => {

View File

@ -11,7 +11,7 @@ import { PanelDescription } from "./islands/PanelDescription.mjs";
export default async (api, db) => {
const { html, debounce, addMutationListener, addPanelView } = api,
behavior = (await db.get("smoothScrolling")) ? "smooth" : "auto",
scroller = ".notion-frame > .notion-scroller",
scroller = ".notion-frame .notion-scroller",
equation = ".notion-text-equation-token",
annotation = (await db.get("equationRendering"))
? ".katex-html"
@ -78,10 +78,9 @@ export default async (api, db) => {
$heading._$outline = html`<${Heading}
indent=${getHeadingLevel($heading)}
onclick=${() => {
$scroller.scrollTo({
top: getBlockOffset($heading) - 24,
behavior,
});
if (!$scroller) return;
const top = getBlockOffset($heading) - 24;
$scroller.scrollTo({ top, behavior });
}}
>${getHeadingTitle($heading)}
<//>`;
@ -96,6 +95,7 @@ export default async (api, db) => {
size-[6px] rounded-full bg-[color:var(--theme--fg-secondary)]"
></span>`,
onScroll = () => {
if (!$scroller) return;
const $h = getHeadings().find(($h) => {
return $scroller.scrollTop < getBlockOffset($h) - 16;
})?._$outline;

View File

@ -1,5 +1,5 @@
/**
* notion-enhancer: scroll to top
* notion-enhancer: scroller
* (c) 2021 CloudHill <rl.cloudhill@gmail.com> (https://github.com/CloudHill)
* (c) 2024 dragonwocky <thedragonring.bod@gmail.com> (https://dragonwocky.me/)
* (https://notion-enhancer.github.io/) under the MIT license
@ -14,7 +14,7 @@ export default async (api, db) => {
distanceUntilShown = await db.get("distanceUntilScrollToTopShown"),
scrollUnit = await db.get("scrollDistanceUnit"),
behavior = (await db.get("smoothScrolling")) ? "smooth" : "auto",
scroller = ".notion-frame > .notion-scroller";
scroller = ".notion-frame .notion-scroller";
let $scroller;
const scrollTo = (top) => $scroller?.scroll({ top, behavior }),

View File

@ -21,7 +21,7 @@
},
{
"type": "toggle",
"key": "HidelashMenu",
"key": "hideSlashMenu",
"description": "Hide the commands popup when typing '/'.",
"value": false
},