From 1703feb4219add781aa921e9bd2f032e8eac188f Mon Sep 17 00:00:00 2001
From: Ian Jones <51156018+ianjon3s@users.noreply.github.com>
Date: Thu, 25 Jul 2024 18:53:23 +0100
Subject: [PATCH] style: Tighten editor interface layout (#3455)
---
.../src/components/EditorNavMenu.tsx | 8 +--
editor.planx.uk/src/components/Header.tsx | 51 ++++++++++++-------
.../src/pages/FlowEditor/index.tsx | 4 +-
.../src/pages/layout/AuthenticatedLayout.tsx | 12 +++--
editor.planx.uk/src/theme.ts | 3 ++
editor.planx.uk/src/themeOverrides.d.ts | 19 +++++++
6 files changed, 70 insertions(+), 27 deletions(-)
diff --git a/editor.planx.uk/src/components/EditorNavMenu.tsx b/editor.planx.uk/src/components/EditorNavMenu.tsx
index ecc8216885..9f985d965a 100644
--- a/editor.planx.uk/src/components/EditorNavMenu.tsx
+++ b/editor.planx.uk/src/components/EditorNavMenu.tsx
@@ -24,8 +24,8 @@ interface Route {
accessibleBy: Role[];
}
-const MENU_WIDTH_COMPACT = "52px";
-const MENU_WIDTH_FULL = "178px";
+const MENU_WIDTH_COMPACT = "51px";
+const MENU_WIDTH_FULL = "164px";
const Root = styled(Box, {
shouldForwardProp: (prop) => prop !== "compact",
@@ -218,8 +218,8 @@ function EditorNavMenu() {
) : (
-
- {title}
+
+ {title}
)}
diff --git a/editor.planx.uk/src/components/Header.tsx b/editor.planx.uk/src/components/Header.tsx
index 16947e9bc0..e3c94fa36c 100644
--- a/editor.planx.uk/src/components/Header.tsx
+++ b/editor.planx.uk/src/components/Header.tsx
@@ -37,7 +37,6 @@ import {
LINE_HEIGHT_BASE,
} from "theme";
import { ApplicationPath } from "types";
-import Permission from "ui/editor/Permission";
import Reset from "ui/icons/Reset";
import { useStore } from "../pages/FlowEditor/lib/store";
@@ -46,7 +45,8 @@ import AnalyticsDisabledBanner from "./AnalyticsDisabledBanner";
import { ConfirmationDialog } from "./ConfirmationDialog";
import TestEnvironmentBanner from "./TestEnvironmentBanner";
-export const HEADER_HEIGHT = 74;
+const HEADER_HEIGHT_PUBLIC = 74;
+export const HEADER_HEIGHT_EDITOR = 56;
const Root = styled(AppBar)(({ theme }) => ({
color: theme.palette.common.white,
@@ -66,8 +66,19 @@ const BreadcrumbsLink = styled(Link)(({ theme }) => ({
borderBottom: "1px solid rgba(255, 255, 255, 0.75)",
})) as typeof Link;
-const StyledToolbar = styled(MuiToolbar)(() => ({
- height: HEADER_HEIGHT,
+const PublicHeader = styled(MuiToolbar)(() => ({
+ height: HEADER_HEIGHT_PUBLIC,
+}));
+
+const EditorHeader = styled(MuiToolbar)(({ theme }) => ({
+ [theme.breakpoints.up("md")]: {
+ minHeight: HEADER_HEIGHT_EDITOR,
+ },
+}));
+
+const EditorHeaderContainer = styled(Box)(({ theme }) => ({
+ width: "100%",
+ padding: theme.spacing(0, 2),
}));
const InnerContainer = styled(Box)(() => ({
@@ -97,6 +108,9 @@ const ProfileSection = styled(MuiToolbar)(({ theme }) => ({
justifyContent: "space-between",
alignItems: "center",
marginRight: theme.spacing(1),
+ [theme.breakpoints.up("md")]: {
+ minHeight: HEADER_HEIGHT_EDITOR,
+ },
}));
const StyledPopover = styled(Popover)(({ theme }) => ({
@@ -119,10 +133,10 @@ const StyledPaper = styled(Paper)(({ theme }) => ({
}));
const Logo = styled("img")(() => ({
- height: HEADER_HEIGHT - 5,
+ height: HEADER_HEIGHT_PUBLIC - 5,
width: "100%",
maxWidth: 140,
- maxHeight: HEADER_HEIGHT - 20,
+ maxHeight: HEADER_HEIGHT_PUBLIC - 20,
objectFit: "contain",
}));
@@ -135,7 +149,7 @@ const LogoLink = styled(Link)(() => ({
const SkipLink = styled("a")(({ theme }) => ({
tabIndex: 0,
width: "100vw",
- height: HEADER_HEIGHT / 2,
+ height: HEADER_HEIGHT_PUBLIC / 2,
backgroundColor: theme.palette.background.dark,
color: theme.palette.common.white,
textDecoration: "underline",
@@ -214,6 +228,7 @@ const Breadcrumbs: React.FC = () => {
href={"/"}
prefetch={false}
{...(isStandalone && { target: "_blank" })}
+ variant="body1"
>
Planâś•
@@ -225,6 +240,7 @@ const Breadcrumbs: React.FC = () => {
href={`/${team.slug}`}
prefetch={false}
{...(isStandalone && { target: "_blank" })}
+ variant="body1"
>
{team.slug}
@@ -241,6 +257,7 @@ const Breadcrumbs: React.FC = () => {
component={ReactNaviLink}
href={rootFlowPath(false)}
prefetch={false}
+ variant="body1"
>
{route.data.flow}
@@ -249,9 +266,9 @@ const Breadcrumbs: React.FC = () => {
{route.data.flow && (
<>
{useStore.getState().canUserEditTeam(team.slug) ? (
-
+
) : (
-
+
)}
>
)}
@@ -290,7 +307,6 @@ const NavBar: React.FC = () => {
display: "flex",
flexDirection: "column",
justifyContent: "center",
- minHeight: HEADER_HEIGHT,
}}
>
{`Section ${index} of ${sectionCount}`}
@@ -347,7 +363,7 @@ const PublicToolbar: React.FC<{
return (
<>
Skip to main content
-
+
@@ -378,7 +394,7 @@ const PublicToolbar: React.FC<{
-
+
{!showCentredServiceTitle && (
@@ -438,8 +454,8 @@ const EditorToolbar: React.FC<{
return (
<>
-
-
+
+
@@ -464,6 +480,7 @@ const EditorToolbar: React.FC<{
aria-label="Toggle Menu"
onClick={handleMenuToggle}
size="large"
+ sx={{ padding: "0.25em" }}
>
-
+
Account
@@ -489,8 +506,8 @@ const EditorToolbar: React.FC<{
)}
-
-
+
+
{user && (
({
alignItems: "stretch",
overflow: "hidden",
flexGrow: 1,
- maxHeight: `calc(100vh - ${HEADER_HEIGHT}px)`,
+ maxHeight: `calc(100vh - ${HEADER_HEIGHT_EDITOR}px)`,
}));
const FlowEditor: React.FC = ({ flow, breadcrumbs }) => {
diff --git a/editor.planx.uk/src/pages/layout/AuthenticatedLayout.tsx b/editor.planx.uk/src/pages/layout/AuthenticatedLayout.tsx
index ae94fef872..437ddee99b 100644
--- a/editor.planx.uk/src/pages/layout/AuthenticatedLayout.tsx
+++ b/editor.planx.uk/src/pages/layout/AuthenticatedLayout.tsx
@@ -2,7 +2,7 @@ import Box from "@mui/material/Box";
import { containerClasses } from "@mui/material/Container";
import { styled } from "@mui/material/styles";
import EditorNavMenu from "components/EditorNavMenu";
-import { HEADER_HEIGHT } from "components/Header";
+import { HEADER_HEIGHT_EDITOR } from "components/Header";
import React, { PropsWithChildren } from "react";
import { DndProvider } from "react-dnd";
import { HTML5Backend } from "react-dnd-html5-backend";
@@ -22,11 +22,15 @@ const DashboardContainer = styled(Box)(({ theme }) => ({
display: "flex",
flexDirection: "row",
width: "100%",
- minHeight: `calc(100vh - ${HEADER_HEIGHT}px)`,
+ minHeight: `calc(100vh - ${HEADER_HEIGHT_EDITOR}px)`,
overflow: "hidden",
[`& > .${containerClasses.root}`]: {
- paddingTop: theme.spacing(5),
- paddingBottom: theme.spacing(5),
+ paddingTop: theme.spacing(3),
+ paddingBottom: theme.spacing(3),
+ [theme.breakpoints.up("lg")]: {
+ paddingTop: theme.spacing(5),
+ paddingBottom: theme.spacing(5),
+ },
},
}));
diff --git a/editor.planx.uk/src/theme.ts b/editor.planx.uk/src/theme.ts
index 82adecc79b..861f58d3da 100644
--- a/editor.planx.uk/src/theme.ts
+++ b/editor.planx.uk/src/theme.ts
@@ -188,6 +188,9 @@ const getThemeOptions = ({
body2: {
fontSize: "1rem",
},
+ body3: {
+ fontSize: "0.913rem",
+ }
},
palette,
breakpoints: {
diff --git a/editor.planx.uk/src/themeOverrides.d.ts b/editor.planx.uk/src/themeOverrides.d.ts
index 5cf7b5c497..c12271d279 100644
--- a/editor.planx.uk/src/themeOverrides.d.ts
+++ b/editor.planx.uk/src/themeOverrides.d.ts
@@ -1,6 +1,8 @@
import "@mui/material/Chip";
// eslint-disable-next-line no-restricted-imports
import "@mui/material/styles/createPalette";
+import "@mui/material/styles";
+import "@mui/material/Typography";
import { RadioProps } from "@mui/material/Radio";
@@ -92,3 +94,20 @@ declare module "@mui/material" {
variant?: keyof RadioPropsVariantOverrides;
}
}
+
+
+// Add a new typography variant "body3" for use in the editor
+declare module "@mui/material/styles" {
+ interface TypographyVariants {
+ body3: React.CSSProperties;
+ }
+ interface TypographyVariantsOptions {
+ body3?: React.CSSProperties;
+ }
+}
+
+declare module "@mui/material/Typography" {
+ interface TypographyPropsVariantOverrides {
+ body3: true;
+ }
+}