nerburish / yii2-masonry-view
ListView widget improved to use Masonry (http://masonry.desandro.com/)
Installs: 1 551
Dependents: 0
Suggesters: 0
Security: 0
Stars: 5
Watchers: 3
Forks: 2
Open Issues: 2
Type:yii2-extension
pkg:composer/nerburish/yii2-masonry-view
Requires
This package is not auto-updated.
Last update: 2025-10-12 01:39:44 UTC
README
Yii2 widget to extend the Yii2 ListView for use it as Masonry grid layout (http://masonry.desandro.com/)
Installation
The preferred way to install this extension is through composer.
Either run
php composer.phar require --prefer-dist nerburish/yii2-masonry-view "*"
or add
"nerburish/yii2-masonry-view": "*"
to the require section of your composer.json file.
Usage
The usage is similar to default ListView Widget (http://www.yiiframework.com/doc-2.0/yii-widgets-listview.html)
You just need a dataProvider and prepare the item template for your model.
In clientOptions you can pass the Masonry options to modify the plugin behavior (see http://masonry.desandro.com/options.html)
You can also attach a cssFile for styling the grid.
Exemple
We have this model:
class MyModel extends \yii\base\Model
{
	public $id;
	
	public $title;
	
	public $description;
}
And this item template named _item.php:
<h3><?= $model->title ?></h3>
<p><?= $model->description ?></p>
Finally, in our view, we run the widget:
<?php echo \nerburish\masonryview\MasonryView::widget([
	'dataProvider' => $dataProvider,
	'itemView' => '_item',
	'clientOptions' => [
	  'gutterWidth' => 15,
	],
	'cssFile' => [
		"@web/css/masonry-demo.css"		
	]
]) ?>
Below, the css used for the demo:
/* ---- grid ---- */
.grid {
  box-sizing: border-box;
}
/* clearfix */
.grid:after {
  content: '';
  display: block;
  clear: both;
}
/* ---- grid-item ---- */
.grid-item {
  width: 20%;
  padding: 10px;  
  margin: 10px auto;
  float: left;
  background: #e4e4e4;
  border-radius: 5px;
}
You may be interested in Isotope Widget because implements Masonry and other layouts and funcionalities at once. https://github.com/nerburish/yii2-isotope-view
There is also a MatchHeight.js implementation of ListView widget: https://github.com/nerburish/yii2-match-height-view
