MiniMasonry.js
MiniMasonry.js copied to clipboard
Changing window size or zoom level collapses gutters
Hey there, thanks for such a clean, simple library!
Platform
macOS 12.6, Brave Version 1.45.113 Chromium: 107.0.5304.62 (Official Build) (arm64)
Setup
- Parent
div
, set to relative, which I apply minimasonry to - Child
div
s, set to absolute (have the following Tailwind classes applied:absolute flex flex-col justify-between p-4 shadow-md border-l-4 bg-gray-100 border-gray-500 rounded-sm tracking-widest leading-loose mb-4
new MiniMasonry({
baseWidth: 512, // Target width of elements.
container: this.element, // Container selector or HTMLElement. Required.
gutter: 16, // Width / height of gutter between elements. Use gutterX / gutterY to set different values.
surroundingGutter: false, // Set left gutter on first columns and right gutter on last.
});
Description
I'm experiencing an issue where gutters between items are reduced in size as the result of resizing the window/viewport. All of the following screenshots were taken on the same page load (no refresh):
Default page load:
data:image/s3,"s3://crabby-images/42d82/42d825a96911b6fb48544ec3805c9b5d62d73ec5" alt="Xnip2022-10-31_07-46-43"
After reducing window size:
data:image/s3,"s3://crabby-images/4bc82/4bc82a692cfd2167fa9d521b1805e69c5544e599" alt="Xnip2022-10-31_07-46-57"
After increasing window size (after being reduced):
data:image/s3,"s3://crabby-images/5fd35/5fd355444111e989b1b744b4ee946cfcce902bd6" alt="Xnip2022-10-31_07-47-23"
Images of other viewport sizes:
data:image/s3,"s3://crabby-images/d9ec7/d9ec7f5d19eb6e9f027cb566675b8224b55e2ab7" alt="Xnip2022-10-31_07-47-42"
data:image/s3,"s3://crabby-images/2dab1/2dab126ae2402c0cf4df3679b040bfe801c42277" alt="Xnip2022-10-31_07-47-31"
This happens on zoom level change too, not just window resize. This is after reducing and increasing and reducing zoom level a bunch:
data:image/s3,"s3://crabby-images/7a808/7a808391770e0c630866361637c04b35a6613bd3" alt="image"
Manually calling a redraw after window resize doesn't seem to have any effect. Looking at the library, it seems like a redraw automatically happens on resize, anyway.
Is there anything I can do to alleviate this, even if it's a bit hacky?