-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathmasonry-common.js
81 lines (63 loc) · 1.73 KB
/
masonry-common.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
var colCount = 0;
var colWidth = 610;
var margin = 20;
var windowWidth = 0;
var blocks = [];
function setupBlocks() {
windowWidth = $(window).width();
colWidth = $('.block').outerWidth();
colCount = Math.floor(windowWidth/(colWidth+margin));
for(var i=0;i<colCount;i++) {
blocks.push(margin);
}
positionBlocks();
}
$(window).resize(setupBlocks);
function positionBlocks() {
$('.block').each(function(){
var min = Array.min(blocks);
var index = $.inArray(min, blocks);
var leftPos = margin+(index*(colWidth+margin));
$(this).css({
'left':leftPos+'px',
'top':min+'px'
});
blocks[index] = min+block.outerHeight()+margin;
});
}
// Function to get the Min value in Array
Array.min = function(array) {
return Math.min.apply(Math, array);
};
/* Do this Masonry stuff after the page is loaded */
$(document).ready(function(){
var containerID = "#mediawiki-masonry-main-page-container";
imagesLoaded( containerID, {}, function(){
var msnry = new Masonry( containerID, {
columnWidth: 310,
gutter: 0,
itemSelector: '.item'
});
});
});
/* ALTERNATE Function to reload after images are done loading */
/*
// initialize Masonry
var $container = $('#container').masonry();
// layout Masonry again after all images have loaded
$container.imagesLoaded( function() {
$container.masonry();
});
*/
/* Function to make blocks toggle size when clicked */
/* COMMENTED OUT TO KEEP THINGS SIMPLE AT FIRST
$( function() {
var $container = $('.js-masonry').masonry({
columnWidth: 10
});
$container.on( 'click', '.item-content', function() {
$( this ).parent('.item').toggleClass('is-expanded');
$container.masonry();
});
});
*/