Created
February 14, 2024 11:28
-
-
Save audunolsen/762f62b9940ad1378a42dfd96bbd74d1 to your computer and use it in GitHub Desktop.
Sticky icons drawer scrollable both axis
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
function App() { | |
return ( | |
<div className={styles.container}> | |
{/* */} | |
{/* */} | |
<div className={styles.blockScroller}> | |
{/* */} | |
{/* */} | |
<div className={styles.inlineScroller}> | |
<div className={styles.drawer}> | |
{[...Array(50).keys()].map((i) => ( | |
<div key={i} className={styles.drawerEntry}> | |
<div className={styles.sticky}>{i}</div> | |
<div>Hello World</div> | |
</div> | |
))} | |
</div> | |
<div className={styles.scrollPadding} /> | |
</div> | |
</div> | |
</div> | |
); | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
:root { | |
--aside-width: 300px; | |
--scroll-offset: 50px; | |
} | |
* { | |
overscroll-behavior: none; | |
} | |
.container { | |
border: 2px solid palevioletred; | |
padding: 10px; | |
height: 100%; | |
width: 100%; | |
} | |
.block-scroller { | |
height: 100%; | |
width: 100%; | |
// padding: 10px; | |
border: 2px solid darkmagenta; | |
overflow: hidden scroll; | |
} | |
.inline-scroller { | |
// padding: 10px; | |
height: fit-content; | |
width: 100%; | |
overflow-x: scroll; | |
display: flex; | |
flex-direction: row; | |
overscroll-behavior: none auto; | |
scroll-snap-type: x mandatory; | |
} | |
.drawer { | |
scroll-snap-align: start; | |
display: flex; | |
gap: 10px; | |
flex-direction: column; | |
flex-shrink: 0; | |
border: 2px solid cornflowerblue; | |
width: var(--aside-width); | |
} | |
.drawer-entry { | |
gap: 10px; | |
display: flex; | |
flex-direction: row; | |
.sticky { | |
position: sticky; | |
left: 0; | |
} | |
} | |
.scroll-padding { | |
scroll-snap-align: end; | |
display: flex; | |
flex-shrink: 0; | |
width: calc(100% - var(--scroll-offset)); | |
border: 2px solid chocolate; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment