/*! waterfall - v0.1.73 - 2015-12-01
* //wlog.cn/waterfall/
* Copyright (c) 2015 bingdian; Licensed MIT */
! function(a, b, c, d) {
"use strict";
function e(b, c) {
this.$element = a(b),
this.options = a.extend(!0, {}, h, c),
this.colHeightArray = [],
this.styleQueue = [],
this._init()
}
var f = a(b),
g = "waterfall",
h = {
itemCls: "waterfall-item",
prefix: "waterfall",
fitWidth: !0,
colWidth: 240,
gutterWidth: 10,
gutterHeight: 10,
align: "center",
minCol: 1,
maxCol: d,
maxPage: d,
bufferPixel: -50,
containerStyle: {
position: "relative"
},
resizable: !0,
isFadeIn: !1,
isAnimated: !1,
animationOptions: {},
isAutoPrefill: !0,
checkImagesLoaded: !0,
path: d,
dataType: "json",
params: {},
headers: {},
loadingMsg: '
Loading...
',
state: {
isDuringAjax: !1,
isProcessingData: !1,
isResizing: !1,
isPause: !1,
curPage: 1
},
callbacks: {
loadingStart: function(a) {
a.show()
},
loadingFinished: function(a, b) {
b ? a.remove() : a.fadeOut()
},
loadingError: function(a, b) {
a.html("Data load faild, please try again later.")
},
renderData: function(b, c) {
var d, e;
return "json" === c || "jsonp" === c ? (d = a("#waterfall-tpl").html(),
(e = Handlebars.compile(d))(b)) : b
}
},
debug: !1
};
e.prototype = {
constructor: e,
_debug: function() {
!0 === this.options.debug && ("undefined" != typeof console && "function" == typeof console.log ? 1 === Array.prototype.slice.call(arguments).length && "string" == typeof Array.prototype.slice.call(arguments)[0] ? console.log(Array.prototype.slice.call(arguments).toString()) : console.log(Array.prototype.slice.call(arguments)) : Function.prototype.bind || "undefined" == typeof console || "object" != typeof console.log || Function.prototype.call.call(console.log, console, Array.prototype.slice.call(arguments)))
},
_init: function(a) {
var b = this.options,
c = b.path;
return this._setColumns(), this._initContainer(),
this._resetColumnsHeightArray(),
this.reLayout(a), c ? (b.isAutoPrefill &&
this._prefill(), b.resizable &&
this._doResize(), void this._doScroll()) : void
this._debug("Invalid path")
},
_initContainer: function() {
var b = this.options,
c = b.prefix;
a("body").css({
overflow: "auto"
}), this.$element.css(this.options.containerStyle).addClass(c + "-container"), this.$element.after('' + b.loadingMsg + '
'), this.$loading = a("#" + c + "-loading"), this.$message = a("#" + c + "-message")
},
_getColumns: function() {
var a = this.options,
b = a.fitWidth ? this.$element.parent() : this.$element,
c = "BODY" === b[0].tagName ? b.width() - 20 : b.width(),
d = a.colWidth,
e = a.gutterWidth,
f = a.minCol,
g = a.maxCol,
h = Math.floor(c / (d + e)),
i = Math.max(h, f);
return g && i > g ? g : i
},
_setColumns: function() {
this.cols = this._getColumns()
},
_getItems: function(a) {
var b = a.filter("." + this.options.itemCls).css({
position: "absolute"
});
return b
},
_resetColumnsHeightArray: function() {
var a, b = this.cols;
for (this.colHeightArray.length = b, a = 0; b > a; a++) this.colHeightArray[a] = 0
},
layout: function(a, b) {
var c, d, e, f, g, h, i = this.options,
j = this.options.isFadeIn ? this._getItems(a).css({
opacity: 0
}).animate({
opacity: 1
}) : this._getItems(a),
k = this.options.isAnimated && this.options.state.isResizing ? "animate" : "css",
l = i.animationOptions,
m = i.colWidth,
n = i.gutterWidth,
o = this.colHeightArray.length,
p = i.align;
for (this.$element.append(j), "center" === p ? (c = (this.$element.width() - m * o - n * (o - 1)) / 2, c = c > 0 ? c : 0) : "left" === p ? c = 0 : "right" === p && (c = this.$element.width() - m * o - n * (o - 1)), e = 0, g = j.length; g > e; e++) this._placeItems(j[e], c);
for (f = 0, h = this.styleQueue.length; h > f; f++) d = this.styleQueue[f], d.$el[k](d.style, l);
this.$element.height(Math.max.apply({}, this.colHeightArray)), this.styleQueue = [], this.options.state.isResizing = !1, this.options.state.isProcessingData = !1, b && b.call(j)
},
reLayout: function(a) {
var b = this.$element.find("." + this.options.itemCls);
this._resetColumnsHeightArray(), this.layout(b, a)
},
_placeItems: function(b, c) {
var d, e, f = a(b),
g = this.options,
h = g.colWidth,
i = g.gutterWidth,
j = g.gutterHeight,
k = this.colHeightArray,
l = k.length,
m = Math.min.apply({}, k),
n = a.inArray(m, k);
d = f.hasClass(g.prefix + "-item-fixed-left") ? 0 : f.hasClass(g.prefix + "-item-fixed-right") ? l > 1 ? l - 1 : 0 : n, e = {
left: (h + i) * d + c,
top: k[d]
}, this.styleQueue.push({
$el: f,
style: e
}), k[d] += f.outerHeight() + j
},
prepend: function(a, b) {
this.$element.prepend(a), this.reLayout(b)
},
append: function(a, b) {
this.$element.append(a), this.reLayout(b)
},
removeItems: function(a, b) {
this.$element.find(a).remove(), this.reLayout(b)
},
option: function(b, c) {
a.isPlainObject(b) && (this.options = a.extend(!0, this.options, b), "function" == typeof c && c(), this._init())
},
pause: function(a) {
this.options.state.isPause = !0, "function" == typeof a && a()
},
resume: function(a) {
this.options.state.isPause = !1, "function" == typeof a && a()
},
_requestData: function(b) {
var c, e = this,
f = this.options,
g = f.maxPage,
h = f.state.curPage++,
i = f.path,
j = f.dataType,
k = f.params,
l = f.headers;
return g !== d && h > g ? (f.state.isBeyondMaxPage = !0, void f.callbacks.loadingFinished(this.$loading, f.state.isBeyondMaxPage)) : (c = "function" == typeof i ? i(h) : i.join(h), this._debug("heading into ajax", c + a.param(k)), f.callbacks.loadingStart(this.$loading), f.state.isDuringAjax = !0, f.state.isProcessingData = !0, void a.ajax({
url: c,
data: k,
headers: l,
dataType: j,
success: function(a) {
e._handleResponse(a, b), e.options.state.isDuringAjax = !1
},
error: function(a) {
e._responeseError("error")
}
}))
},
_handleResponse: function(b, c) {
var d = this,
e = this.options,
f = a.trim(e.callbacks.renderData(b, e.dataType)),
g = a(f),
h = e.checkImagesLoaded;
h ? g.imagesLoaded(function() {
d.append(g, c), d.options.callbacks.loadingFinished(d.$loading, d.options.state.isBeyondMaxPage)
}) : (d.append(g, c), d.options.callbacks.loadingFinished(d.$loading, d.options.state.isBeyondMaxPage))
},
_responeseError: function(a) {
this.$loading.hide(), this.options.callbacks.loadingError(this.$message, a), "end" !== a && "error" !== a && (a = "unknown"), this._debug("Error", a)
},
_nearbottom: function() {
var a = this.options,
b = Math.min.apply({}, this.colHeightArray),
c = f.scrollTop() + f.height() - this.$element.offset().top - b;
return this._debug("math:", c), c > a.bufferPixel
},
_prefill: function() {
this.$element.height() <= f.height() && this._scroll()
},
_scroll: function() {
var a = this.options,
b = a.state,
c = this;
b.isProcessingData || b.isDuringAjax || b.isInvalidPage || b.isPause || this._nearbottom() && this._requestData(function() {
setTimeout(function() {
c._scroll()
}, 100)
})
},
_doScroll: function() {
var a, b = this;
f.bind("scroll", function() {
a && clearTimeout(a), a = setTimeout(function() {
b._scroll()
}, 100)
})
},
_resize: function() {
var a = this.cols,
b = this._getColumns();
(b !== a || "left" !== this.options.align) && (this.options.state.isResizing = !0, this.cols = b, this.reLayout(), this._prefill())
},
_doResize: function() {
var a, b = this;
f.bind("resize", function() {
a && clearTimeout(a), a = setTimeout(function() {
b._resize()
}, 100)
})
}
}, a.fn[g] = function(b) {
if ("string" == typeof b) {
var c = Array.prototype.slice.call(arguments, 1);
this.each(function() {
var d = a.data(this, "plugin_" + g);
return d ? a.isFunction(d[b]) && "_" !== b.charAt(0) ? void d[b].apply(d, c) : void d._debug('no such method "' + b + '"') : void d._debug("instance is not initialization")
})
} else this.each(function() {
a.data(this, "plugin_" + g) || a.data(this, "plugin_" + g, new e(this, b))
});
return this
}
}(jQuery, window, document),
function(a, b) {
"use strict";
var c = "";
a.fn.imagesLoaded = function(d) {
function e() {
var b = a(m),
c = a(n);
i && (n.length ? i.reject(k, b, c) : i.resolve(k)), a.isFunction(d) && d.call(h, k, b, c)
}
function f(a) {
g(a.target, "error" === a.type)
}
function g(b, d) {
b.src !== c && -1 === a.inArray(b, l) && (l.push(b), d ? n.push(b) : m.push(b), a.data(b, "imagesLoaded", {
isBroken: d,
src: b.src
}), j && i.notifyWith(a(b), [d, k, a(m), a(n)]), k.length === l.length && (setTimeout(e), k.unbind(".imagesLoaded", f)))
}
var h = this,
i = a.isFunction(a.Deferred) ? a.Deferred() : 0,
j = a.isFunction(i.notify),
k = h.find("img").add(h.filter("img")),
l = [],
m = [],
n = [];
return a.isPlainObject(d) && a.each(d, function(a, b) {
"callback" === a ? d = b : i && i[a](b)
}), k.length ? k.bind("load.imagesLoaded error.imagesLoaded", f).each(function(d, e) {
var f = e.src,
h = a.data(e, "imagesLoaded");
return h && h.src === f ? void g(e, h.isBroken) : e.complete && e.naturalWidth !== b ? void g(e, 0 === e.naturalWidth || 0 === e.naturalHeight) : void((e.readyState || e.complete) && (e.src = c, e.src = f))
}) : e(), i ? i.promise(h) : h
}
}(jQuery);