Skip to content

Commit

Permalink
fix(ForgeLayout): fix performance/bg attachment (#1551)
Browse files Browse the repository at this point in the history
## πŸ“ Changes

- Stick background on scroll
- Try to fix some perf issues

## βœ… Checklist

Easy UI has certain UX standards that must be met. In general,
non-trivial changes should meet the following criteria:

- [x] Visuals match Design Specs in Figma
- [x] Stories accompany any component changes
- [x] Code is in accordance with our style guide
- [x] Design tokens are utilized
- [x] Unit tests accompany any component changes
- [x] TSDoc is written for any API surface area
- [x] Specs are up-to-date
- [x] Console is free from warnings
- [x] No accessibility violations are reported
- [x] Cross-browser check is performed (Chrome, Safari, Firefox)
- [x] Changeset is added

~Strikethrough~ any items that are not applicable to this pull request.
  • Loading branch information
stephenjwatkins authored Dec 19, 2024
1 parent 40e322a commit 2be5e1c
Show file tree
Hide file tree
Showing 4 changed files with 46 additions and 34 deletions.
5 changes: 5 additions & 0 deletions .changeset/cyan-goats-promise.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"@easypost/easy-ui": patch
---

fix(ForgeLayout): attach bg
57 changes: 29 additions & 28 deletions easy-ui-react/src/ForgeLayout/ForgeLayout.module.scss
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,8 @@
padding-right: component-token("forge-layout", "shell-gutter");
gap: component-token("forge-layout", "shell-gutter");
min-height: 100svh;
background-color: design-token("color.neutral.025");
position: relative;
overflow-x: clip;
}

.modeTest {
Expand All @@ -37,6 +37,15 @@
@include component-token("forge-layout", "header-border-width", 2px);
}

.bg {
position: fixed;
top: 0;
left: 0;
width: 100vw;
height: 100vh;
background-color: design-token("color.neutral.025");
}

.backgroundDecoration01 {
background-image: url(""),
url("");
Expand All @@ -53,13 +62,30 @@
}

.header {
position: sticky;
top: 0;
height: component-token("forge-layout", "header-height");

display: flex;
flex-wrap: nowrap;
align-items: center;
justify-content: space-between;
min-width: 0;

border-bottom: 2px solid transparent;
z-index: calc(#{design-token("z-index.nav")} + 1);
z-index: design-token("z-index.nav");
}

.headerBg {
position: absolute;
top: 0;
left: -100vw;
width: 300vw;
height: component-token("forge-layout", "header-height");

background-color: design-token("color.neutral.025");
border-bottom: component-token("forge-layout", "header-border-width") solid
component-token("forge-layout", "header-border-color");
}

.content {
Expand All @@ -68,33 +94,8 @@
}

.controls {
position: relative;
display: flex;
align-items: center;
gap: design-token("space.2");
}

.fauxContainer {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;

display: flex;
flex-direction: column;
pointer-events: none;
}

.fauxHeader {
background-color: design-token("color.neutral.025");
border-bottom: component-token("forge-layout", "header-border-width") solid
component-token("forge-layout", "header-border-color");
z-index: design-token("z-index.nav");
}

.fauxHeader,
.header {
position: sticky;
top: 0;
height: component-token("forge-layout", "header-height");
}
2 changes: 1 addition & 1 deletion easy-ui-react/src/ForgeLayout/ForgeLayout.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,7 @@ const Template = (args: Partial<ForgeLayoutProps>) => {
</ForgeLayout.Header>
<ForgeLayout.Content>
<Card background="primary" boxShadow="1" variant="solid">
<div style={{ height: 1000 }}>Page Content</div>
<div style={{ height: 4000 }}>Page Content</div>
</Card>
</ForgeLayout.Content>
</ForgeLayout.Body>
Expand Down
16 changes: 11 additions & 5 deletions easy-ui-react/src/ForgeLayout/ForgeLayout.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -168,28 +168,34 @@ export function ForgeLayout(props: ForgeLayoutProps) {
} = props;
const className = classNames(
styles.ForgeLayout,
styles[variationName("backgroundDecoration", backgroundDecoration)],
styles[variationName("mode", mode)],
styles[variationName("navState", navState)],
);
const bgClassName = classNames(
styles.bg,
styles[variationName("backgroundDecoration", backgroundDecoration)],
);
const context = useMemo(() => {
return { mode, navState };
}, [mode, navState]);
return (
<ForgeLayoutContext.Provider value={context}>
<div className={bgClassName} />
<div className={className} data-testid="ForgeLayout">
{children}
<div className={styles.fauxContainer}>
<div className={styles.fauxHeader}></div>
</div>
</div>
</ForgeLayoutContext.Provider>
);
}

function ForgeLayoutHeader(props: ForgeLayoutHeaderProps) {
const { children } = props;
return <header className={styles.header}>{children}</header>;
return (
<header className={styles.header}>
<div className={styles.headerBg}></div>
{children}
</header>
);
}

function ForgeLayoutControls(props: ForgeLayoutControlsProps) {
Expand Down

0 comments on commit 2be5e1c

Please sign in to comment.