if you wish to have IE8 support, v2 with React 0.14 is the highest version available.
- Usage
- Basic usage
- Custom props
- Accessing Masonry instance
- Events
- Using with Webpack
- Dependencies
- Webpack config [DEPRECATED]
A React.js Masonry component. (Also available as a mixin if needed)
-
The component is bundled with Masonry, so no additional dependencies needed!
-
You can optionally include Masonry as a script tag if there should be any reason for doing so
<script src='//cdnjs.cloudflare.com/ajax/libs/masonry/3.1.5/masonry.pkgd.min.js' />
-
To use the component just require the module.
npm install --save react-masonry-component
var React = require('react');
var Masonry = require('react-masonry-component');
var masonryOptions = {
transitionDuration: 0
};
var Gallery = React.createClass({
render: function () {
var childElements = this.props.elements.map(function(element){
return (
<li className="image-element-class">
<img src={element.src} />
</li>
);
});
return (
<Masonry
className={'my-gallery-class'} // default ''
elementType={'ul'} // default 'div'
options={masonryOptions} // default {}
disableImagesLoaded={false} // default false
updateOnEachImageLoad={false} // default false and works only if disableImagesLoaded is false
>
{childElements}
</Masonry>
);
}
});
module.exports = Gallery;
ES6-style modules are also supported, just use:
import Masonry from 'react-masonry-component';
You can also include your own custom props - EG: inline-style and event handlers.
var React = require('react');
var Masonry = require('react-masonry-component');
var masonryOptions = {
transitionDuration: 0
};
var style = {
backgroundColor: 'tomato'
};
var Gallery = React.createClass({
handleClick: function() { },
render: function () {
return (
<Masonry
className={'my-gallery-class'}
style={style}
onClick={this.handleClick}
>
{...}
</Masonry>
);
}
});
module.exports = Gallery;
Should you need to access the instance of Masonry (for example to listen to masonry events)
you can do so by using refs
.
var React = require('react');
var Masonry = require('react-masonry-component');
var Gallery = React.createClass({
handleLayoutComplete: function() { },
componentDidMount: function() {
this.masonry.on('layoutComplete', this.handleLayoutComplete);
},
componentWillUnmount: function() {
this.masonry.off('layoutComplete', this.handleLayoutComplete);
},
render: function () {
return (
<Masonry
ref={function(c) {this.masonry = this.masonry || c.masonry;}.bind(this)}
>
{...}
</Masonry>
);
}
});
module.exports = Gallery;
onImagesLoaded
- triggered when all images are loaded or after each image is loaded whenupdateOnEachImageLoad
is set totrue
onLayoutComplete
- triggered after a layout and all positioning transitions have completed.onRemoveComplete
- triggered after an item element has been removed
var Gallery = React.createClass({
componentDidMount: function() {
this.hide();
},
handleImagesLoaded: function(imagesLoadedInstance) {
this.show();
},
render: function(){
return (
<Masonry
onImagesLoaded={this.handleImagesLoaded}
onLayoutComplete={laidOutItems => this.handleLayoutComplete(laidOutItems)}
onRemoveComplete={removedItems => this.handleRemoveComplete(removedItems)}
>
{...}
</Masonry>
)
}
});
Because webpack resolves AMD first, you need to use the imports-loader in order to disable AMD and require as commonJS modules.
First ensure you have the imports-loader installed
npm install imports-loader --save
Then add the rules for the imports-loader to your webpack config.
The babel-loader
is used below to show how you can use the 2 together.
loaders: [
{
test: /\.jsx?$/,
exclude: /node_modules/,
loader: 'babel'
},
{
test: /masonry|imagesloaded|fizzy\-ui\-utils|desandro\-|outlayer|get\-size|doc\-ready|eventie|eventemitter/,
loader: 'imports?define=>false&this=>window'
}
]