Masonry
The Masonry component is a useful tool for creating responsive grid layouts with varying column widths. It is highly customizable with the breakpointCols
, className
, and columnClassName
props, and can be easily integrated into any React project.
Installation
npm install @madeinhaus/masonry
Import
import Masonry from '@madeinhaus/masonry';
import '@madeinhaus/masonry/dist/index.css';
Props
breakpointCols
: an object that specifies the number of columns to be used at various breakpoints. This prop is optional and defaults to{ default: 2 }
.className
: a string that allows for adding a CSS class to the root element of the component.columnClassName
: a string that allows for adding a CSS class to the column elements of the component.children
: a required prop that represents the child elements to be rendered in the Masonry component.
Usage
MasonryDemoBasic.tsx
import Masonry from '@madeinhaus/masonry';
import styles from './MasonryDemo.module.css';
const MasonryDemoBasic: React.FC = ({ images }: { images: string[] }) => {
return (
<Masonry
breakpointCols={{
default: 2,
768: 3,
1024: 4,
}}
>
{images.map((src, index) => {
return (
<figure key={index} className={styles.item}>
<img src={src} />
<figcaption className={styles.caption}>
{index + 1} <br />
</figcaption>
</figure>
);
})}
</Masonry>
);
};
export default MasonryDemoBasic;
MasonryDemo.module.css
.item {
position: relative;
}
.caption {
position: absolute;
top: 0;
left: 0;
color: #e600e6;
background-color: #fff0ff;
padding: 0.5rem;
border-bottom-right-radius: 0.5rem;
}
data:image/s3,"s3://crabby-images/2f169/2f1698829651015c46a3abe4830b8b4ea11a80ac" alt=""
data:image/s3,"s3://crabby-images/2e399/2e399c710e61e6b6d118d131399a53bab90095cb" alt=""
data:image/s3,"s3://crabby-images/7bee6/7bee6066e27898af4c195062edac4b49b9c30b08" alt=""
data:image/s3,"s3://crabby-images/813ee/813ee5587f7a3cbe23b656a6d81a705d1d62a5f4" alt=""
data:image/s3,"s3://crabby-images/9c58e/9c58efb28c0a5fa82b07ef6fdfcd42e79fadba44" alt=""
data:image/s3,"s3://crabby-images/9c82a/9c82a60b3aacf33657d01dbff2d010acd7f282c9" alt=""
data:image/s3,"s3://crabby-images/b2a99/b2a997284142c1d1086d8c1dd5058faee0ae6ca0" alt=""
data:image/s3,"s3://crabby-images/91876/918761b4a745c4e5ada7223e157e283bc97746bd" alt=""
data:image/s3,"s3://crabby-images/85b10/85b105934e6e75573b287fba5f1280eaca5ca358" alt=""
data:image/s3,"s3://crabby-images/52642/52642fbca7b26bec0c9ef841fb568ccf95cac91c" alt=""
data:image/s3,"s3://crabby-images/59990/599900a53440614ca7ece25af3a3fbdd92bc698c" alt=""
data:image/s3,"s3://crabby-images/3fcba/3fcba3106499897183863f37ad0c3d00773e232d" alt=""
data:image/s3,"s3://crabby-images/2408c/2408c9df97fbcc4129b5ec7b3fae18316668c519" alt=""
data:image/s3,"s3://crabby-images/76bc1/76bc13f2bd9eaca0b0c30cbe8a903a22bed67d15" alt=""
data:image/s3,"s3://crabby-images/013d4/013d48624ef637d478b0315962ac3848f9dd89ba" alt=""
data:image/s3,"s3://crabby-images/089e2/089e2b839aadf36bb0629162342fb56de9d5ebe8" alt=""
data:image/s3,"s3://crabby-images/f10c2/f10c276f57d94354e6696004726950315b48c924" alt=""
data:image/s3,"s3://crabby-images/a2e0b/a2e0bbef485f610056f1848802a031548e9953af" alt=""
data:image/s3,"s3://crabby-images/46fd3/46fd36aa9d903be43a3c8804effdef13b24b1a5b" alt=""
data:image/s3,"s3://crabby-images/e52ed/e52edd5fb597878470f2142ca1f6423fac5f1712" alt=""