Interactivity
Scroll Snap Align
Utilities for controlling the scroll offset around items in a snap container.
Unsupported
This functionality is not yet supported! If you need this, reach out to us on #smp-warp-design-system.
Quick reference
Class | Description |
---|---|
snap-start | Unsupported |
snap-end | Unsupported |
snap-center | Unsupported |
snap-align-none | Unsupported |
Basic usage
Snapping to the center
Use the snap-center
utility to snap an element to its center when being scrolled inside a snap container.
snap-center
data:image/s3,"s3://crabby-images/53a01/53a01cf9b9e01bc93c4b0b959874df7601bb5b38" alt=""
data:image/s3,"s3://crabby-images/0d9ef/0d9ef7a9d8c3de40092d6400a6ec6fae38e392b4" alt=""
data:image/s3,"s3://crabby-images/b8b24/b8b2446dd7ef66c9c9affe7a0e0e161568f388bf" alt=""
data:image/s3,"s3://crabby-images/a282f/a282f5950950f02f55b64baf0f27ee8063a781a5" alt=""
data:image/s3,"s3://crabby-images/8cf6a/8cf6a6a235235867cae1cefad3310c8de9b6cf83" alt=""
data:image/s3,"s3://crabby-images/092dc/092dc4623b2e77c26603dde0d2189d9feeb897af" alt=""
<div class="snap-x ...">
<div class="snap-center ..."><img src="..." /></div>
<div class="snap-center ..."><img src="..." /></div>
<!-- ... -->
<div class="snap-center ..."><img src="..." /></div>
</div>
Snapping to the start
Use the snap-start
utility to snap an element to its start when being scrolled inside a snap container.
snap-start
data:image/s3,"s3://crabby-images/53a01/53a01cf9b9e01bc93c4b0b959874df7601bb5b38" alt=""
data:image/s3,"s3://crabby-images/0d9ef/0d9ef7a9d8c3de40092d6400a6ec6fae38e392b4" alt=""
data:image/s3,"s3://crabby-images/b8b24/b8b2446dd7ef66c9c9affe7a0e0e161568f388bf" alt=""
data:image/s3,"s3://crabby-images/a282f/a282f5950950f02f55b64baf0f27ee8063a781a5" alt=""
data:image/s3,"s3://crabby-images/8cf6a/8cf6a6a235235867cae1cefad3310c8de9b6cf83" alt=""
data:image/s3,"s3://crabby-images/092dc/092dc4623b2e77c26603dde0d2189d9feeb897af" alt=""
<div class="snap-x ...">
<div class="snap-start ..."><img src="..." /></div>
<div class="snap-start ..."><img src="..." /></div>
<!-- ... -->
<div class="snap-start ..."><img src="..." /></div>
</div>
Snapping to the end
Use the snap-end
utility to snap an element to its end when being scrolled inside a snap container.
snap-end
data:image/s3,"s3://crabby-images/53a01/53a01cf9b9e01bc93c4b0b959874df7601bb5b38" alt=""
data:image/s3,"s3://crabby-images/0d9ef/0d9ef7a9d8c3de40092d6400a6ec6fae38e392b4" alt=""
data:image/s3,"s3://crabby-images/b8b24/b8b2446dd7ef66c9c9affe7a0e0e161568f388bf" alt=""
data:image/s3,"s3://crabby-images/a282f/a282f5950950f02f55b64baf0f27ee8063a781a5" alt=""
data:image/s3,"s3://crabby-images/8cf6a/8cf6a6a235235867cae1cefad3310c8de9b6cf83" alt=""
data:image/s3,"s3://crabby-images/092dc/092dc4623b2e77c26603dde0d2189d9feeb897af" alt=""
<div class="snap-x ...">
<div class="snap-end ..."><img src="..." /></div>
<div class="snap-end ..."><img src="..." /></div>
<!-- ... -->
<div class="snap-end ..."><img src="..." /></div>
</div>
Applying conditionally
Hover, focus, and other states
Warp lets you conditionally apply utility classes in different states using variant modifiers. For example, use hover:snap-start
to only apply the snap-start
utility on hover.
<div class="snap-center hover:snap-start"></div>
Breakpoints and media queries
You can also use variant modifiers to target media queries like responsive breakpoints, dark mode, prefers-reduced-motion, and more. For example, use md:snap-start
to apply the snap-start
utility at only medium screen sizes and above.
<div class="snap-center md:snap-start"></div>