fix initial client load position (fixes #36)

This commit is contained in:
Grant 2024-05-29 11:42:53 -06:00
parent 6308992e02
commit 0cf27d80f3
2 changed files with 18 additions and 2 deletions

View File

@ -3,6 +3,7 @@ import {
createContext, createContext,
useContext, useContext,
useEffect, useEffect,
useRef,
useState, useState,
} from "react"; } from "react";
import { IRouterData, Router } from "../lib/router"; import { IRouterData, Router } from "../lib/router";
@ -52,7 +53,11 @@ export const TemplateContext = ({ children }: PropsWithChildren) => {
const [y, setY] = useState(routerData.template?.y || 0); const [y, setY] = useState(routerData.template?.y || 0);
const [opacity, setOpacity] = useState(100); const [opacity, setOpacity] = useState(100);
const initAt = useRef<number>();
useEffect(() => { useEffect(() => {
initAt.current = Date.now();
const handleNavigate = (data: IRouterData) => { const handleNavigate = (data: IRouterData) => {
if (data.template) { if (data.template) {
setEnable(true); setEnable(true);
@ -74,7 +79,18 @@ export const TemplateContext = ({ children }: PropsWithChildren) => {
useEffect(() => { useEffect(() => {
Router.setTemplate({ enabled: enable, width, x, y, url }); Router.setTemplate({ enabled: enable, width, x, y, url });
Router.queueUpdate();
if (!initAt.current) {
console.debug("TemplateContext updating router but no initAt");
} else if (Date.now() - initAt.current < 2 * 1000) {
console.debug(
"TemplateContext updating router too soon after init",
Date.now() - initAt.current
);
}
if (initAt.current && Date.now() - initAt.current > 2 * 1000)
Router.queueUpdate();
}, [enable, width, x, y, url]); }, [enable, width, x, y, url]);
return ( return (

View File

@ -70,7 +70,7 @@ class _Router extends EventEmitter<RouterEvents> {
const url = this.getURL(); const url = this.getURL();
if (!url) return; if (!url) return;
console.log("[Router] Updating URL"); console.log("[Router] Updating URL", url);
window.history.replaceState({}, "", url); window.history.replaceState({}, "", url);
} }