Change top bar to flexbox (#753)

pull/760/head
onespaceman 2024-02-26 12:10:31 -05:00 committed by GitHub
parent e290245621
commit e3a2dbdd11
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 7 additions and 40 deletions

View File

@ -46,38 +46,6 @@ export function TopBar({
lhs?: ComponentChildren; lhs?: ComponentChildren;
rhs?: ComponentChildren; rhs?: ComponentChildren;
}) { }) {
// Another one of my less proud moments:
// Somehow I cannot seem to proerply limit the width of the page name, so I'm doing
// it this way. If you have a better way to do this, please let me know!
useEffect(() => {
function resizeHandler() {
const editorWidth = parseInt(
getComputedStyle(document.getElementById("sb-root")!).getPropertyValue(
"--editor-width",
),
);
const currentPageElement = document.getElementById("sb-current-page");
const actionsElement = document.querySelector(".sb-actions");
if (currentPageElement && actionsElement) {
// Temporarily make it very narrow to give the parent space
currentPageElement.style.width = "10px";
const innerDiv = currentPageElement.parentElement!.parentElement!;
// Then calculate a new width
const actionsWidth = actionsElement.clientWidth;
// console.log("Editor width", editorWidth);
currentPageElement.style.width = `${
innerDiv.clientWidth - actionsWidth - 40
}px`;
}
}
globalThis.addEventListener("resize", resizeHandler);
// Stop listening on unmount
return () => {
globalThis.removeEventListener("resize", resizeHandler);
};
}, []);
return ( return (
<div <div
@ -94,8 +62,8 @@ export function TopBar({
className={isLoading className={isLoading
? "sb-loading" ? "sb-loading"
: unsavedChanges : unsavedChanges
? "sb-unsaved" ? "sb-unsaved"
: "sb-saved"} : "sb-saved"}
> >
<MiniEditor <MiniEditor
text={pageName ?? ""} text={pageName ?? ""}

View File

@ -65,14 +65,13 @@ body {
max-width: var(--#{"editor-width"}); max-width: var(--#{"editor-width"});
margin: auto; margin: auto;
font-size: 28px; font-size: 28px;
padding: 10px 0; padding: 10px 20px;
display: flex; display: flex;
flex-direction: row; flex-direction: row;
.wrapper { .wrapper {
width: 100%; width: 100%;
padding: 0 20px; display: flex;
position: relative;
} }
.sb-notifications { .sb-notifications {
@ -112,10 +111,10 @@ body {
} }
.sb-actions { .sb-actions {
display: flex;
align-items: baseline;
flex: 0 0 auto;
text-align: right; text-align: right;
position: absolute;
right: 15px;
top: 0;
} }
.progress-wrapper { .progress-wrapper {