Masonry module for Angular2
angular2-masonry is in development and not ready for production use.
Feel free to install and try it out, but depend on it at your own risk.
Installation
npm install angular2-masonry --save
If you're using SystemJS add angular2-masonry
and masonry-layout
to your configuration:
```json
packages: {
"angular2-masonry": { "defaultExtension": "js", "main": "index" }
},
map: {
"angular2-masonry": "nodemodules/angular2-masonry",
"masonry-layout": "nodemodules/masonry-layout/dist/masonry.pkgd.js"
}
```
Usage
ImportMasonryModule
into your app's modules:
``` typescript
import { MasonryModule } from 'angular2-masonry';
@NgModule({
imports:
MasonryModule
})
```
```typescript
@Component({
selector: 'my-component',
template: `
<masonry>
<masonry-brick class="brick" *ngFor="let brick of bricks">{{brick.title}}</masonry-brick>
</masonry>
`,
styles: [`
.brick { width: 200px; }
`]
})
class MyComponent {
bricks = [
{title: 'Brick 1'},
{title: 'Brick 2'},
{title: 'Brick 3'},
{title: 'Brick 4'},
{title: 'Brick 5'},
{title: 'Brick 6'}
]
}
```
Configuration
Options
Read about Masonry options here: http://masonry.desandro.com/options.html Theoptions
-attribute takes an object with the following properties:
- itemSelector: string;
- columnWidth: number | string;
- gutter: number;
- percentPosition: boolean;
- stamp: string;
- fitWidth: boolean;
- originLeft: boolean;
- originTop: boolean;
- containerStyle: string;
- transitionDuration: string;
- resize: boolean;
- initLayout: boolean;
Examples
Inline object: ```html options="{ transitionDuration: '0.8s' }"> ``` From parent component: ```javascript import { MasonryOptions } from 'angular2-masonry'; public myOptions: MasonryOptions = { transitionDuration: '0.8s' }; ``` ```html options="myOptions"> ```imagesLoaded
>NOTE: Will throw error if globalimagesLoaded
not available.
Delay adding brick until all images in brick are loaded.
To activate imagesLoaded set useImagesLoaded
to true
.
```html
useImagesLoaded="true">
```
index.html:
```html
```
Events
layoutComplete: EventEmitter<any[]>
Triggered after a layout and all positioning transitions have completed.
>http://masonry.desandro.com/events.html#layoutcomplete
removeComplete: EventEmitter<any[]>
Triggered after an item element has been removed.
>http://masonry.desandro.com/events.html#removecomplete
Examples
```html ```Demo
- Plunkr: https://plnkr.co/edit/mmi5tk6hvzEazYQUGZUC?p=preview
- Demo project: https://github.com/jelgblad/angular2-masonry-demo