18 changed files with 1561 additions and 152 deletions
|
After Width: | Height: | Size: 5.9 KiB |
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -0,0 +1 @@ |
|||
.api-single,.note-single{margin:25px 0 25px}#api{padding-top:0}.api-menu,.note-menu{margin-bottom:10px}.api-grid,.note-grid{padding-left:25px;padding-right:25px} |
|||
|
After Width: | Height: | Size: 4.2 KiB |
@ -0,0 +1,150 @@ |
|||
@font-face { |
|||
font-family: "iconfont"; /* Project id 2374637 */ |
|||
src: url('iconfont.1.0.2.woff2?t=1636012998858') format('woff2'), |
|||
url('iconfont.1.0.2.woff?t=1636012998858') format('woff'), |
|||
url('iconfont.1.0.2.ttf?t=1636012998858') format('truetype'); |
|||
} |
|||
|
|||
.iconfont { |
|||
font-family: "iconfont" !important; |
|||
font-style: normal; |
|||
-webkit-font-smoothing: antialiased; |
|||
-moz-osx-font-smoothing: grayscale; |
|||
} |
|||
|
|||
.icon-jilu:before { |
|||
content: "\e66b"; |
|||
} |
|||
|
|||
.icon-dianzan2:before { |
|||
content: "\e602"; |
|||
} |
|||
|
|||
.icon-zan:before { |
|||
content: "\e61b"; |
|||
} |
|||
|
|||
.icon-detailscomments:before { |
|||
content: "\e618"; |
|||
} |
|||
|
|||
.icon-weibiaoti-:before { |
|||
content: "\e60e"; |
|||
} |
|||
|
|||
.icon-guanyu2:before { |
|||
content: "\e728"; |
|||
} |
|||
|
|||
.icon-hammer:before { |
|||
content: "\e87c"; |
|||
} |
|||
|
|||
.icon-ziyuan:before { |
|||
content: "\e635"; |
|||
} |
|||
|
|||
.icon-shezhi2:before { |
|||
content: "\e639"; |
|||
} |
|||
|
|||
.icon-shuju-zuopinlei:before { |
|||
content: "\e62d"; |
|||
} |
|||
|
|||
.icon-B:before { |
|||
content: "\e6fc"; |
|||
} |
|||
|
|||
.icon-zhiyuanshouye6:before { |
|||
content: "\e627"; |
|||
} |
|||
|
|||
.icon-redis:before { |
|||
content: "\e61a"; |
|||
} |
|||
|
|||
.icon-celery:before { |
|||
content: "\eb5b"; |
|||
} |
|||
|
|||
.icon-rabbitmq:before { |
|||
content: "\ec75"; |
|||
} |
|||
|
|||
.icon-youjian5:before { |
|||
content: "\e60b"; |
|||
} |
|||
|
|||
.icon-dingwei:before { |
|||
content: "\e656"; |
|||
} |
|||
|
|||
.icon-vertical_line:before { |
|||
content: "\e63b"; |
|||
} |
|||
|
|||
.icon-deng:before { |
|||
content: "\e619"; |
|||
} |
|||
|
|||
.icon-Html:before { |
|||
content: "\e696"; |
|||
} |
|||
|
|||
.icon-CDNjiasu:before { |
|||
content: "\e6c3"; |
|||
} |
|||
|
|||
.icon-iconfont:before { |
|||
content: "\e610"; |
|||
} |
|||
|
|||
.icon-jquery:before { |
|||
content: "\e655"; |
|||
} |
|||
|
|||
.icon-xiazai:before { |
|||
content: "\e601"; |
|||
} |
|||
|
|||
.icon-bootstrap:before { |
|||
content: "\e600"; |
|||
} |
|||
|
|||
.icon-API1:before { |
|||
content: "\e692"; |
|||
} |
|||
|
|||
.icon-vue1:before { |
|||
content: "\e8ad"; |
|||
} |
|||
|
|||
.icon-suanfamoxing:before { |
|||
content: "\e616"; |
|||
} |
|||
|
|||
.icon-django:before { |
|||
content: "\eb7b"; |
|||
} |
|||
|
|||
.icon-linux:before { |
|||
content: "\e63a"; |
|||
} |
|||
|
|||
.icon-python:before { |
|||
content: "\e68e"; |
|||
} |
|||
|
|||
.icon-icon_on_the_top:before { |
|||
content: "\e626"; |
|||
} |
|||
|
|||
.icon-weixin:before { |
|||
content: "\e660"; |
|||
} |
|||
|
|||
.icon-menu-fill:before { |
|||
content: "\e62a"; |
|||
} |
|||
|
|||
Binary file not shown.
Binary file not shown.
Binary file not shown.
|
After Width: | Height: | Size: 5.7 KiB |
@ -0,0 +1,614 @@ |
|||
!function (t, i, s) { |
|||
"use strict"; |
|||
var e, n = t.document, o = t.Modernizr, r = function (t) { |
|||
return t.charAt(0).toUpperCase() + t.slice(1) |
|||
}, a = "Moz Webkit O Ms".split(" "), h = function (t) { |
|||
var i, s = n.documentElement.style; |
|||
if ("string" == typeof s[t]) return t; |
|||
t = r(t); |
|||
for (var e = 0, o = a.length; o > e; e++) if (i = a[e] + t, "string" == typeof s[i]) return i |
|||
}, l = h("transform"), u = h("transitionProperty"), c = { |
|||
csstransforms: function () { |
|||
return !!l |
|||
}, csstransforms3d: function () { |
|||
var t = !!h("perspective"); |
|||
if (t) { |
|||
var s = " -o- -moz- -ms- -webkit- -khtml- ".split(" "), |
|||
e = "@media (" + s.join("transform-3d),(") + "modernizr)", |
|||
n = i("<style>" + e + "{#modernizr{height:3px}}</style>").appendTo("head"), |
|||
o = i('<div id="modernizr" />').appendTo("html"); |
|||
t = 3 === o.height(), o.remove(), n.remove() |
|||
} |
|||
return t |
|||
}, csstransitions: function () { |
|||
return !!u |
|||
} |
|||
}; |
|||
if (o) for (e in c) o.hasOwnProperty(e) || o.addTest(e, c[e]); else { |
|||
o = t.Modernizr = {_version: "1.6ish: miniModernizr for Isotope"}; |
|||
var d, f = " "; |
|||
for (e in c) d = c[e](), o[e] = d, f += " " + (d ? "" : "no-") + e; |
|||
i("html").addClass(f) |
|||
} |
|||
if (o.csstransforms) { |
|||
var m = o.csstransforms3d ? { |
|||
translate: function (t) { |
|||
return "translate3d(" + t[0] + "px, " + t[1] + "px, 0) " |
|||
}, scale: function (t) { |
|||
return "scale3d(" + t + ", " + t + ", 1) " |
|||
} |
|||
} : { |
|||
translate: function (t) { |
|||
return "translate(" + t[0] + "px, " + t[1] + "px) " |
|||
}, scale: function (t) { |
|||
return "scale(" + t + ") " |
|||
} |
|||
}, p = function (t, s, e) { |
|||
var n, o, r = i.data(t, "isoTransform") || {}, a = {}, h = {}; |
|||
a[s] = e, i.extend(r, a); |
|||
for (n in r) o = r[n], h[n] = m[n](o); |
|||
var u = h.translate || "", c = h.scale || "", d = u + c; |
|||
i.data(t, "isoTransform", r), t.style[l] = d |
|||
}; |
|||
i.cssNumber.scale = !0, i.cssHooks.scale = { |
|||
set: function (t, i) { |
|||
p(t, "scale", i) |
|||
}, get: function (t, s) { |
|||
var e = i.data(t, "isoTransform"); |
|||
return e && e.scale ? e.scale : 1 |
|||
} |
|||
}, i.fx.step.scale = function (t) { |
|||
i.cssHooks.scale.set(t.elem, t.now + t.unit) |
|||
}, i.cssNumber.translate = !0, i.cssHooks.translate = { |
|||
set: function (t, i) { |
|||
p(t, "translate", i) |
|||
}, get: function (t, s) { |
|||
var e = i.data(t, "isoTransform"); |
|||
return e && e.translate ? e.translate : [0, 0] |
|||
} |
|||
} |
|||
} |
|||
var y, g; |
|||
o.csstransitions && (y = { |
|||
WebkitTransitionProperty: "webkitTransitionEnd", |
|||
MozTransitionProperty: "transitionend", |
|||
OTransitionProperty: "oTransitionEnd otransitionend", |
|||
transitionProperty: "transitionend" |
|||
}[u], g = h("transitionDuration")); |
|||
var v, _ = i.event, A = i.event.handle ? "handle" : "dispatch"; |
|||
_.special.smartresize = { |
|||
setup: function () { |
|||
i(this).bind("resize", _.special.smartresize.handler) |
|||
}, teardown: function () { |
|||
i(this).unbind("resize", _.special.smartresize.handler) |
|||
}, handler: function (t, i) { |
|||
var s = this, e = arguments; |
|||
t.type = "smartresize", v && clearTimeout(v), v = setTimeout(function () { |
|||
_[A].apply(s, e) |
|||
}, "execAsap" === i ? 0 : 100) |
|||
} |
|||
}, i.fn.smartresize = function (t) { |
|||
return t ? this.bind("smartresize", t) : this.trigger("smartresize", ["execAsap"]) |
|||
}, i.Isotope = function (t, s, e) { |
|||
this.element = i(s), this._create(t), this._init(e) |
|||
}; |
|||
var w = ["width", "height"], C = i(t); |
|||
i.Isotope.settings = { |
|||
resizable: !0, |
|||
layoutMode: "masonry", |
|||
containerClass: "isotope", |
|||
itemClass: "isotope-item", |
|||
hiddenClass: "isotope-hidden", |
|||
hiddenStyle: {opacity: 0, scale: .001}, |
|||
visibleStyle: {opacity: 1, scale: 1}, |
|||
containerStyle: {position: "relative", overflow: "hidden"}, |
|||
animationEngine: "best-available", |
|||
animationOptions: {queue: !1, duration: 800}, |
|||
sortBy: "original-order", |
|||
sortAscending: !0, |
|||
resizesContainer: !0, |
|||
transformsEnabled: !0, |
|||
itemPositionDataEnabled: !1 |
|||
}, i.Isotope.prototype = { |
|||
_create: function (t) { |
|||
this.options = i.extend({}, i.Isotope.settings, t), this.styleQueue = [], this.elemCount = 0; |
|||
var s = this.element[0].style; |
|||
this.originalStyle = {}; |
|||
var e = w.slice(0); |
|||
for (var n in this.options.containerStyle) e.push(n); |
|||
for (var o = 0, r = e.length; r > o; o++) n = e[o], this.originalStyle[n] = s[n] || ""; |
|||
this.element.css(this.options.containerStyle), this._updateAnimationEngine(), this._updateUsingTransforms(); |
|||
var a = { |
|||
"original-order": function (t, i) { |
|||
return i.elemCount++, i.elemCount |
|||
}, random: function () { |
|||
return Math.random() |
|||
} |
|||
}; |
|||
this.options.getSortData = i.extend(this.options.getSortData, a), this.reloadItems(), this.offset = { |
|||
left: parseInt(this.element.css("padding-left") || 0, 10), |
|||
top: parseInt(this.element.css("padding-top") || 0, 10) |
|||
}; |
|||
var h = this; |
|||
setTimeout(function () { |
|||
h.element.addClass(h.options.containerClass) |
|||
}, 0), this.options.resizable && C.bind("smartresize.isotope", function () { |
|||
h.resize() |
|||
}), this.element.delegate("." + this.options.hiddenClass, "click", function () { |
|||
return !1 |
|||
}) |
|||
}, _getAtoms: function (t) { |
|||
var i = this.options.itemSelector, s = i ? t.filter(i).add(t.find(i)) : t, e = {position: "absolute"}; |
|||
return s = s.filter(function (t, i) { |
|||
return 1 === i.nodeType |
|||
}), this.usingTransforms && (e.left = 0, e.top = 0), s.css(e).addClass(this.options.itemClass), this.updateSortData(s, !0), s |
|||
}, _init: function (t) { |
|||
this.$filteredAtoms = this._filter(this.$allAtoms), this._sort(), this.reLayout(t) |
|||
}, option: function (t) { |
|||
if (i.isPlainObject(t)) { |
|||
this.options = i.extend(!0, this.options, t); |
|||
var s; |
|||
for (var e in t) s = "_update" + r(e), this[s] && this[s]() |
|||
} |
|||
}, _updateAnimationEngine: function () { |
|||
var t, i = this.options.animationEngine.toLowerCase().replace(/[ _\-]/g, ""); |
|||
switch (i) { |
|||
case "css": |
|||
case "none": |
|||
t = !1; |
|||
break; |
|||
case "jquery": |
|||
t = !0; |
|||
break; |
|||
default: |
|||
t = !o.csstransitions |
|||
} |
|||
this.isUsingJQueryAnimation = t, this._updateUsingTransforms() |
|||
}, _updateTransformsEnabled: function () { |
|||
this._updateUsingTransforms() |
|||
}, _updateUsingTransforms: function () { |
|||
var t = this.usingTransforms = this.options.transformsEnabled && o.csstransforms && o.csstransitions && !this.isUsingJQueryAnimation; |
|||
t || (delete this.options.hiddenStyle.scale, delete this.options.visibleStyle.scale), this.getPositionStyles = t ? this._translate : this._positionAbs |
|||
}, _filter: function (t) { |
|||
var i = "" === this.options.filter ? "*" : this.options.filter; |
|||
if (!i) return t; |
|||
var s = this.options.hiddenClass, e = "." + s, n = t.filter(e), o = n; |
|||
if ("*" !== i) { |
|||
o = n.filter(i); |
|||
var r = t.not(e).not(i).addClass(s); |
|||
this.styleQueue.push({$el: r, style: this.options.hiddenStyle}) |
|||
} |
|||
return this.styleQueue.push({$el: o, style: this.options.visibleStyle}), o.removeClass(s), t.filter(i) |
|||
}, updateSortData: function (t, s) { |
|||
var e, n, o = this, r = this.options.getSortData; |
|||
t.each(function () { |
|||
e = i(this), n = {}; |
|||
for (var t in r) s || "original-order" !== t ? n[t] = r[t](e, o) : n[t] = i.data(this, "isotope-sort-data")[t]; |
|||
i.data(this, "isotope-sort-data", n) |
|||
}) |
|||
}, _sort: function () { |
|||
var t = this.options.sortBy, i = this._getSorter, s = this.options.sortAscending ? 1 : -1, |
|||
e = function (e, n) { |
|||
var o = i(e, t), r = i(n, t); |
|||
return o === r && "original-order" !== t && (o = i(e, "original-order"), r = i(n, "original-order")), (o > r ? 1 : r > o ? -1 : 0) * s |
|||
}; |
|||
this.$filteredAtoms.sort(e) |
|||
}, _getSorter: function (t, s) { |
|||
return i.data(t, "isotope-sort-data")[s] |
|||
}, _translate: function (t, i) { |
|||
return {translate: [t, i]} |
|||
}, _positionAbs: function (t, i) { |
|||
return {left: t, top: i} |
|||
}, _pushPosition: function (t, i, s) { |
|||
i = Math.round(i + this.offset.left), s = Math.round(s + this.offset.top); |
|||
var e = this.getPositionStyles(i, s); |
|||
this.styleQueue.push({ |
|||
$el: t, |
|||
style: e |
|||
}), this.options.itemPositionDataEnabled && t.data("isotope-item-position", {x: i, y: s}) |
|||
}, layout: function (t, i) { |
|||
var s = this.options.layoutMode; |
|||
if (this["_" + s + "Layout"](t), this.options.resizesContainer) { |
|||
var e = this["_" + s + "GetContainerSize"](); |
|||
this.styleQueue.push({$el: this.element, style: e}) |
|||
} |
|||
this._processStyleQueue(t, i), this.isLaidOut = !0 |
|||
}, _processStyleQueue: function (t, s) { |
|||
var e, n, r, a, h = this.isLaidOut && this.isUsingJQueryAnimation ? "animate" : "css", |
|||
l = this.options.animationOptions, u = this.options.onLayout; |
|||
if (n = function (t, i) { |
|||
i.$el[h](i.style, l) |
|||
}, this._isInserting && this.isUsingJQueryAnimation) n = function (t, i) { |
|||
e = i.$el.hasClass("no-transition") ? "css" : h, i.$el[e](i.style, l) |
|||
}; else if (s || u || l.complete) { |
|||
var c = !1, d = [s, u, l.complete], f = this; |
|||
if (r = !0, a = function () { |
|||
if (!c) { |
|||
for (var i, s = 0, e = d.length; e > s; s++) i = d[s], "function" == typeof i && i.call(f.element, t, f); |
|||
c = !0 |
|||
} |
|||
}, this.isUsingJQueryAnimation && "animate" === h) l.complete = a, r = !1; else if (o.csstransitions) { |
|||
for (var m, p = 0, v = this.styleQueue[0], _ = v && v.$el; !_ || !_.length;) { |
|||
if (m = this.styleQueue[p++], !m) return; |
|||
_ = m.$el |
|||
} |
|||
var A = parseFloat(getComputedStyle(_[0])[g]); |
|||
A > 0 && (n = function (t, i) { |
|||
i.$el[h](i.style, l).one(y, a) |
|||
}, r = !1) |
|||
} |
|||
} |
|||
i.each(this.styleQueue, n), r && a(), this.styleQueue = [] |
|||
}, resize: function () { |
|||
this["_" + this.options.layoutMode + "ResizeChanged"]() && this.reLayout() |
|||
}, reLayout: function (t) { |
|||
this["_" + this.options.layoutMode + "Reset"](), this.layout(this.$filteredAtoms, t) |
|||
}, addItems: function (t, i) { |
|||
var s = this._getAtoms(t); |
|||
this.$allAtoms = this.$allAtoms.add(s), i && i(s) |
|||
}, insert: function (t, i) { |
|||
this.element.append(t); |
|||
var s = this; |
|||
this.addItems(t, function (t) { |
|||
var e = s._filter(t); |
|||
s._addHideAppended(e), s._sort(), s.reLayout(), s._revealAppended(e, i) |
|||
}) |
|||
}, appended: function (t, i) { |
|||
var s = this; |
|||
this.addItems(t, function (t) { |
|||
s._addHideAppended(t), s.layout(t), s._revealAppended(t, i) |
|||
}) |
|||
}, _addHideAppended: function (t) { |
|||
this.$filteredAtoms = this.$filteredAtoms.add(t), t.addClass("no-transition"), this._isInserting = !0, this.styleQueue.push({ |
|||
$el: t, |
|||
style: this.options.hiddenStyle |
|||
}) |
|||
}, _revealAppended: function (t, i) { |
|||
var s = this; |
|||
setTimeout(function () { |
|||
t.removeClass("no-transition"), s.styleQueue.push({ |
|||
$el: t, |
|||
style: s.options.visibleStyle |
|||
}), s._isInserting = !1, s._processStyleQueue(t, i) |
|||
}, 10) |
|||
}, reloadItems: function () { |
|||
this.$allAtoms = this._getAtoms(this.element.children()) |
|||
}, remove: function (t, i) { |
|||
this.$allAtoms = this.$allAtoms.not(t), this.$filteredAtoms = this.$filteredAtoms.not(t); |
|||
var s = this, e = function () { |
|||
t.remove(), i && i.call(s.element) |
|||
}; |
|||
t.filter(":not(." + this.options.hiddenClass + ")").length ? (this.styleQueue.push({ |
|||
$el: t, |
|||
style: this.options.hiddenStyle |
|||
}), this._sort(), this.reLayout(e)) : e() |
|||
}, shuffle: function (t) { |
|||
this.updateSortData(this.$allAtoms), this.options.sortBy = "random", this._sort(), this.reLayout(t) |
|||
}, destroy: function () { |
|||
var t = this.usingTransforms, i = this.options; |
|||
this.$allAtoms.removeClass(i.hiddenClass + " " + i.itemClass).each(function () { |
|||
var i = this.style; |
|||
i.position = "", i.top = "", i.left = "", i.opacity = "", t && (i[l] = "") |
|||
}); |
|||
var s = this.element[0].style; |
|||
for (var e in this.originalStyle) s[e] = this.originalStyle[e]; |
|||
this.element.unbind(".isotope").undelegate("." + i.hiddenClass, "click").removeClass(i.containerClass).removeData("isotope"), C.unbind(".isotope") |
|||
}, _getSegments: function (t) { |
|||
var i, s = this.options.layoutMode, e = t ? "rowHeight" : "columnWidth", n = t ? "height" : "width", |
|||
o = t ? "rows" : "cols", a = this.element[n](), |
|||
h = this.options[s] && this.options[s][e] || this.$filteredAtoms["outer" + r(n)](!0) || a; |
|||
i = Math.floor(a / h), i = Math.max(i, 1), this[s][o] = i, this[s][e] = h |
|||
}, _checkIfSegmentsChanged: function (t) { |
|||
var i = this.options.layoutMode, s = t ? "rows" : "cols", e = this[i][s]; |
|||
return this._getSegments(t), this[i][s] !== e |
|||
}, _masonryReset: function () { |
|||
this.masonry = {}, this._getSegments(); |
|||
var t = this.masonry.cols; |
|||
for (this.masonry.colYs = []; t--;) this.masonry.colYs.push(0) |
|||
}, _masonryLayout: function (t) { |
|||
var s = this, e = s.masonry; |
|||
t.each(function () { |
|||
var t = i(this), n = Math.ceil(t.outerWidth(!0) / e.columnWidth); |
|||
if (n = Math.min(n, e.cols), 1 === n) s._masonryPlaceBrick(t, e.colYs); else { |
|||
var o, r, a = e.cols + 1 - n, h = []; |
|||
for (r = 0; a > r; r++) o = e.colYs.slice(r, r + n), h[r] = Math.max.apply(Math, o); |
|||
s._masonryPlaceBrick(t, h) |
|||
} |
|||
}) |
|||
}, _masonryPlaceBrick: function (t, i) { |
|||
for (var s = Math.min.apply(Math, i), e = 0, n = 0, o = i.length; o > n; n++) if (i[n] === s) { |
|||
e = n; |
|||
break |
|||
} |
|||
var r = this.masonry.columnWidth * e, a = s; |
|||
this._pushPosition(t, r, a); |
|||
var h = s + t.outerHeight(!0), l = this.masonry.cols + 1 - o; |
|||
for (n = 0; l > n; n++) this.masonry.colYs[e + n] = h |
|||
}, _masonryGetContainerSize: function () { |
|||
var t = Math.max.apply(Math, this.masonry.colYs); |
|||
return {height: t} |
|||
}, _masonryResizeChanged: function () { |
|||
return this._checkIfSegmentsChanged() |
|||
}, _fitRowsReset: function () { |
|||
this.fitRows = {x: 0, y: 0, height: 0} |
|||
}, _fitRowsLayout: function (t) { |
|||
var s = this, e = this.element.width(), n = this.fitRows; |
|||
t.each(function () { |
|||
var t = i(this), o = t.outerWidth(!0), r = t.outerHeight(!0); |
|||
0 !== n.x && o + n.x > e && (n.x = 0, n.y = n.height), s._pushPosition(t, n.x, n.y), n.height = Math.max(n.y + r, n.height), n.x += o |
|||
}) |
|||
}, _fitRowsGetContainerSize: function () { |
|||
return {height: this.fitRows.height} |
|||
}, _fitRowsResizeChanged: function () { |
|||
return !0 |
|||
}, _cellsByRowReset: function () { |
|||
this.cellsByRow = {index: 0}, this._getSegments(), this._getSegments(!0) |
|||
}, _cellsByRowLayout: function (t) { |
|||
var s = this, e = this.cellsByRow; |
|||
t.each(function () { |
|||
var t = i(this), n = e.index % e.cols, o = Math.floor(e.index / e.cols), |
|||
r = (n + .5) * e.columnWidth - t.outerWidth(!0) / 2, |
|||
a = (o + .5) * e.rowHeight - t.outerHeight(!0) / 2; |
|||
s._pushPosition(t, r, a), e.index++ |
|||
}) |
|||
}, _cellsByRowGetContainerSize: function () { |
|||
return {height: Math.ceil(this.$filteredAtoms.length / this.cellsByRow.cols) * this.cellsByRow.rowHeight + this.offset.top} |
|||
}, _cellsByRowResizeChanged: function () { |
|||
return this._checkIfSegmentsChanged() |
|||
}, _straightDownReset: function () { |
|||
this.straightDown = {y: 0} |
|||
}, _straightDownLayout: function (t) { |
|||
var s = this; |
|||
t.each(function (t) { |
|||
var e = i(this); |
|||
s._pushPosition(e, 0, s.straightDown.y), s.straightDown.y += e.outerHeight(!0) |
|||
}) |
|||
}, _straightDownGetContainerSize: function () { |
|||
return {height: this.straightDown.y} |
|||
}, _straightDownResizeChanged: function () { |
|||
return !0 |
|||
}, _masonryHorizontalReset: function () { |
|||
this.masonryHorizontal = {}, this._getSegments(!0); |
|||
var t = this.masonryHorizontal.rows; |
|||
for (this.masonryHorizontal.rowXs = []; t--;) this.masonryHorizontal.rowXs.push(0) |
|||
}, _masonryHorizontalLayout: function (t) { |
|||
var s = this, e = s.masonryHorizontal; |
|||
t.each(function () { |
|||
var t = i(this), n = Math.ceil(t.outerHeight(!0) / e.rowHeight); |
|||
if (n = Math.min(n, e.rows), 1 === n) s._masonryHorizontalPlaceBrick(t, e.rowXs); else { |
|||
var o, r, a = e.rows + 1 - n, h = []; |
|||
for (r = 0; a > r; r++) o = e.rowXs.slice(r, r + n), h[r] = Math.max.apply(Math, o); |
|||
s._masonryHorizontalPlaceBrick(t, h) |
|||
} |
|||
}) |
|||
}, _masonryHorizontalPlaceBrick: function (t, i) { |
|||
for (var s = Math.min.apply(Math, i), e = 0, n = 0, o = i.length; o > n; n++) if (i[n] === s) { |
|||
e = n; |
|||
break |
|||
} |
|||
var r = s, a = this.masonryHorizontal.rowHeight * e; |
|||
this._pushPosition(t, r, a); |
|||
var h = s + t.outerWidth(!0), l = this.masonryHorizontal.rows + 1 - o; |
|||
for (n = 0; l > n; n++) this.masonryHorizontal.rowXs[e + n] = h |
|||
}, _masonryHorizontalGetContainerSize: function () { |
|||
var t = Math.max.apply(Math, this.masonryHorizontal.rowXs); |
|||
return {width: t} |
|||
}, _masonryHorizontalResizeChanged: function () { |
|||
return this._checkIfSegmentsChanged(!0) |
|||
}, _fitColumnsReset: function () { |
|||
this.fitColumns = {x: 0, y: 0, width: 0} |
|||
}, _fitColumnsLayout: function (t) { |
|||
var s = this, e = this.element.height(), n = this.fitColumns; |
|||
t.each(function () { |
|||
var t = i(this), o = t.outerWidth(!0), r = t.outerHeight(!0); |
|||
0 !== n.y && r + n.y > e && (n.x = n.width, n.y = 0), s._pushPosition(t, n.x, n.y), n.width = Math.max(n.x + o, n.width), n.y += r |
|||
}) |
|||
}, _fitColumnsGetContainerSize: function () { |
|||
return {width: this.fitColumns.width} |
|||
}, _fitColumnsResizeChanged: function () { |
|||
return !0 |
|||
}, _cellsByColumnReset: function () { |
|||
this.cellsByColumn = {index: 0}, this._getSegments(), this._getSegments(!0) |
|||
}, _cellsByColumnLayout: function (t) { |
|||
var s = this, e = this.cellsByColumn; |
|||
t.each(function () { |
|||
var t = i(this), n = Math.floor(e.index / e.rows), o = e.index % e.rows, |
|||
r = (n + .5) * e.columnWidth - t.outerWidth(!0) / 2, |
|||
a = (o + .5) * e.rowHeight - t.outerHeight(!0) / 2; |
|||
s._pushPosition(t, r, a), e.index++ |
|||
}) |
|||
}, _cellsByColumnGetContainerSize: function () { |
|||
return {width: Math.ceil(this.$filteredAtoms.length / this.cellsByColumn.rows) * this.cellsByColumn.columnWidth} |
|||
}, _cellsByColumnResizeChanged: function () { |
|||
return this._checkIfSegmentsChanged(!0) |
|||
}, _straightAcrossReset: function () { |
|||
this.straightAcross = {x: 0} |
|||
}, _straightAcrossLayout: function (t) { |
|||
var s = this; |
|||
t.each(function (t) { |
|||
var e = i(this); |
|||
s._pushPosition(e, s.straightAcross.x, 0), s.straightAcross.x += e.outerWidth(!0) |
|||
}) |
|||
}, _straightAcrossGetContainerSize: function () { |
|||
return {width: this.straightAcross.x} |
|||
}, _straightAcrossResizeChanged: function () { |
|||
return !0 |
|||
} |
|||
}, i.fn.imagesLoaded = function (t) { |
|||
function s() { |
|||
t.call(n, o) |
|||
} |
|||
|
|||
function e(t) { |
|||
var n = t.target; |
|||
n.src !== a && -1 === i.inArray(n, h) && (h.push(n), --r <= 0 && (setTimeout(s), o.unbind(".imagesLoaded", e))) |
|||
} |
|||
|
|||
var n = this, o = n.find("img").add(n.filter("img")), r = o.length, |
|||
a = "", h = []; |
|||
return r || s(), o.bind("load.imagesLoaded error.imagesLoaded", e).each(function () { |
|||
var t = this.src; |
|||
this.src = a, this.src = t |
|||
}), n |
|||
}; |
|||
var z = function (i) { |
|||
t.console && t.console.error(i) |
|||
}; |
|||
i.fn.isotope = function (t, s) { |
|||
if ("string" == typeof t) { |
|||
var e = Array.prototype.slice.call(arguments, 1); |
|||
this.each(function () { |
|||
var s = i.data(this, "isotope"); |
|||
return s ? i.isFunction(s[t]) && "_" !== t.charAt(0) ? void s[t].apply(s, e) : void z("no such method '" + t + "' for isotope instance") : void z("cannot call methods on isotope prior to initialization; attempted to call method '" + t + "'") |
|||
}) |
|||
} else this.each(function () { |
|||
var e = i.data(this, "isotope"); |
|||
e ? (e.option(t), e._init(s)) : i.data(this, "isotope", new i.Isotope(t, this, s)) |
|||
}); |
|||
return this |
|||
} |
|||
}(window, jQuery); |
|||
let $mainNav = $("#mainNav"); |
|||
let $body = $("body"); |
|||
let $scroll_to_top = $("#scroll-to-top"); |
|||
// 页面顶部时,导航栏背景透明
|
|||
let toggle_flag = true; |
|||
$('.navbar-toggler').click(() => { |
|||
let all_class = $mainNav.attr('class'); |
|||
if (all_class.indexOf('navbar-shrink') === -1) { |
|||
$mainNav.addClass('navbar-shrink'); |
|||
} else { |
|||
if ($mainNav.offset().top <= 10) { |
|||
$mainNav.removeClass("navbar-shrink"); |
|||
} |
|||
} |
|||
toggle_flag = false; |
|||
}); |
|||
// 移动端点击空白处,隐藏菜单
|
|||
$body.click(() => { |
|||
$('.navbar-collapse').collapse('hide'); |
|||
if (toggle_flag) { // 阻止事件冒泡
|
|||
if ($mainNav.offset().top <= 10) { |
|||
$mainNav.removeClass("navbar-shrink"); |
|||
} |
|||
} |
|||
toggle_flag = true; |
|||
}); |
|||
// 移动端点击菜单后,隐藏菜单
|
|||
$('.js-scroll-trigger').click(() => { |
|||
$('.navbar-collapse').collapse('hide'); |
|||
}); |
|||
// 导航栏自动隐藏
|
|||
let previousTop = 0; |
|||
$(window).scroll(() => { |
|||
let currentTop = $(window).scrollTop(); |
|||
if (currentTop - previousTop < -10) { |
|||
// 下划
|
|||
$mainNav.removeClass("show-none"); |
|||
previousTop = currentTop; |
|||
} else if (currentTop - previousTop > 10) { |
|||
// 上划
|
|||
$mainNav.addClass("show-none"); |
|||
$('.navbar-collapse').collapse('hide'); |
|||
previousTop = currentTop; |
|||
} |
|||
if (currentTop < 60) { |
|||
// 首页常显示
|
|||
$mainNav.removeClass("show-none"); |
|||
} |
|||
}); |
|||
// 非顶部刷新时,设置导航栏不透明
|
|||
let navbarCollapse = () => { |
|||
if ($mainNav.offset().top > 10) { |
|||
$mainNav.addClass("navbar-shrink"); |
|||
} else { |
|||
$mainNav.removeClass("navbar-shrink"); |
|||
} |
|||
}; |
|||
navbarCollapse(); |
|||
$(window).scroll(navbarCollapse); |
|||
// 底部滚动
|
|||
$(window).scroll(() => { |
|||
if ($(window).scrollTop() < 100) { |
|||
$scroll_to_top.removeClass('show'); |
|||
} else { |
|||
$scroll_to_top.addClass('show'); |
|||
} |
|||
}); |
|||
$scroll_to_top.click(function (e) { |
|||
e.preventDefault() |
|||
$('html,body').animate({ |
|||
scrollTop: 0 |
|||
}, 700); |
|||
}); |
|||
// 主题切换
|
|||
let like_color = 'darkorange'; |
|||
let like_color0 = '#888888'; |
|||
if ($('body').hasClass('body_dark')) { |
|||
$('.article-single').addClass('body_dark'); |
|||
like_color = '#68a7eb'; |
|||
like_color0 = '#777777'; |
|||
} |
|||
let set_light = () => { |
|||
$('.body_dark').removeClass('body_dark'); |
|||
$('#logo').attr('src', 'logo/logo.png'); |
|||
like_color = 'darkorange'; |
|||
like_color0 = '#888888'; |
|||
let headHTML = document.getElementsByTagName('head')[0].innerHTML; |
|||
headHTML = headHTML.replace(/1A1D24/, "E4EBF8"); |
|||
document.getElementsByTagName('head')[0].innerHTML = headHTML; |
|||
}; |
|||
let set_dark = () => { |
|||
$('#logo').attr('src', 'logo/logo-dark.png'); |
|||
$('body').addClass('body_dark'); |
|||
$('.section-title h3').addClass('body_dark'); |
|||
$('#mainNav').addClass('body_dark'); |
|||
$('#switch_dark').addClass('body_dark'); |
|||
$('.navbar-toggler').addClass('body_dark'); |
|||
$('.blog').addClass('body_dark'); |
|||
$('.section').addClass('body_dark'); |
|||
$('.section button').addClass('body_dark'); |
|||
$('#home').addClass('body_dark'); |
|||
$('#notes .services-inner-box').addClass('body_dark'); |
|||
$('#api .services-inner-box').addClass('body_dark'); |
|||
$('#opus .opus-single').addClass('body_dark'); |
|||
$('#demo .demo-single').addClass('body_dark'); |
|||
$('#contact .contact_form').addClass('body_dark'); |
|||
$('.article-single').addClass('body_dark'); |
|||
like_color = '#68a7eb'; |
|||
like_color0 = '#777777'; |
|||
let headHTML = document.getElementsByTagName('head')[0].innerHTML; |
|||
headHTML = headHTML.replace(/E4EBF8/, "1A1D24"); |
|||
document.getElementsByTagName('head')[0].innerHTML = headHTML; |
|||
}; |
|||
$('.toggle').click(function (e) { |
|||
$(this).toggleClass('toggle--on') |
|||
.toggleClass('toggle--off') |
|||
.addClass('toggle--moving'); |
|||
setTimeout(() => { |
|||
$(this).removeClass('toggle--moving'); |
|||
}, 200); |
|||
let is_dark = $('body').hasClass('body_dark'); |
|||
$('.clock div').css('transition', 'all .3s ease-in-out'); |
|||
setTimeout(() => { |
|||
$('.clock div.minutes').css('transition', 'none'); |
|||
$('.clock div.hours').css('transition', 'none'); |
|||
}, 400); |
|||
setTimeout(() => { |
|||
if (!is_dark) { |
|||
set_dark(); |
|||
} else { |
|||
set_light(); |
|||
} |
|||
}, 100); |
|||
$.ajax({ |
|||
url: '/toggle_dark/', |
|||
type: 'post', |
|||
data: { |
|||
'csrfmiddlewaretoken': $('[name="csrfmiddlewaretoken"]').val(), |
|||
'is_dark': is_dark, |
|||
}, |
|||
success: () => { |
|||
} |
|||
}) |
|||
}); |
|||
@ -0,0 +1,614 @@ |
|||
!function (t, i, s) { |
|||
"use strict"; |
|||
var e, n = t.document, o = t.Modernizr, r = function (t) { |
|||
return t.charAt(0).toUpperCase() + t.slice(1) |
|||
}, a = "Moz Webkit O Ms".split(" "), h = function (t) { |
|||
var i, s = n.documentElement.style; |
|||
if ("string" == typeof s[t]) return t; |
|||
t = r(t); |
|||
for (var e = 0, o = a.length; o > e; e++) if (i = a[e] + t, "string" == typeof s[i]) return i |
|||
}, l = h("transform"), u = h("transitionProperty"), c = { |
|||
csstransforms: function () { |
|||
return !!l |
|||
}, csstransforms3d: function () { |
|||
var t = !!h("perspective"); |
|||
if (t) { |
|||
var s = " -o- -moz- -ms- -webkit- -khtml- ".split(" "), |
|||
e = "@media (" + s.join("transform-3d),(") + "modernizr)", |
|||
n = i("<style>" + e + "{#modernizr{height:3px}}</style>").appendTo("head"), |
|||
o = i('<div id="modernizr" />').appendTo("html"); |
|||
t = 3 === o.height(), o.remove(), n.remove() |
|||
} |
|||
return t |
|||
}, csstransitions: function () { |
|||
return !!u |
|||
} |
|||
}; |
|||
if (o) for (e in c) o.hasOwnProperty(e) || o.addTest(e, c[e]); else { |
|||
o = t.Modernizr = {_version: "1.6ish: miniModernizr for Isotope"}; |
|||
var d, f = " "; |
|||
for (e in c) d = c[e](), o[e] = d, f += " " + (d ? "" : "no-") + e; |
|||
i("html").addClass(f) |
|||
} |
|||
if (o.csstransforms) { |
|||
var m = o.csstransforms3d ? { |
|||
translate: function (t) { |
|||
return "translate3d(" + t[0] + "px, " + t[1] + "px, 0) " |
|||
}, scale: function (t) { |
|||
return "scale3d(" + t + ", " + t + ", 1) " |
|||
} |
|||
} : { |
|||
translate: function (t) { |
|||
return "translate(" + t[0] + "px, " + t[1] + "px) " |
|||
}, scale: function (t) { |
|||
return "scale(" + t + ") " |
|||
} |
|||
}, p = function (t, s, e) { |
|||
var n, o, r = i.data(t, "isoTransform") || {}, a = {}, h = {}; |
|||
a[s] = e, i.extend(r, a); |
|||
for (n in r) o = r[n], h[n] = m[n](o); |
|||
var u = h.translate || "", c = h.scale || "", d = u + c; |
|||
i.data(t, "isoTransform", r), t.style[l] = d |
|||
}; |
|||
i.cssNumber.scale = !0, i.cssHooks.scale = { |
|||
set: function (t, i) { |
|||
p(t, "scale", i) |
|||
}, get: function (t, s) { |
|||
var e = i.data(t, "isoTransform"); |
|||
return e && e.scale ? e.scale : 1 |
|||
} |
|||
}, i.fx.step.scale = function (t) { |
|||
i.cssHooks.scale.set(t.elem, t.now + t.unit) |
|||
}, i.cssNumber.translate = !0, i.cssHooks.translate = { |
|||
set: function (t, i) { |
|||
p(t, "translate", i) |
|||
}, get: function (t, s) { |
|||
var e = i.data(t, "isoTransform"); |
|||
return e && e.translate ? e.translate : [0, 0] |
|||
} |
|||
} |
|||
} |
|||
var y, g; |
|||
o.csstransitions && (y = { |
|||
WebkitTransitionProperty: "webkitTransitionEnd", |
|||
MozTransitionProperty: "transitionend", |
|||
OTransitionProperty: "oTransitionEnd otransitionend", |
|||
transitionProperty: "transitionend" |
|||
}[u], g = h("transitionDuration")); |
|||
var v, _ = i.event, A = i.event.handle ? "handle" : "dispatch"; |
|||
_.special.smartresize = { |
|||
setup: function () { |
|||
i(this).bind("resize", _.special.smartresize.handler) |
|||
}, teardown: function () { |
|||
i(this).unbind("resize", _.special.smartresize.handler) |
|||
}, handler: function (t, i) { |
|||
var s = this, e = arguments; |
|||
t.type = "smartresize", v && clearTimeout(v), v = setTimeout(function () { |
|||
_[A].apply(s, e) |
|||
}, "execAsap" === i ? 0 : 100) |
|||
} |
|||
}, i.fn.smartresize = function (t) { |
|||
return t ? this.bind("smartresize", t) : this.trigger("smartresize", ["execAsap"]) |
|||
}, i.Isotope = function (t, s, e) { |
|||
this.element = i(s), this._create(t), this._init(e) |
|||
}; |
|||
var w = ["width", "height"], C = i(t); |
|||
i.Isotope.settings = { |
|||
resizable: !0, |
|||
layoutMode: "masonry", |
|||
containerClass: "isotope", |
|||
itemClass: "isotope-item", |
|||
hiddenClass: "isotope-hidden", |
|||
hiddenStyle: {opacity: 0, scale: .001}, |
|||
visibleStyle: {opacity: 1, scale: 1}, |
|||
containerStyle: {position: "relative", overflow: "hidden"}, |
|||
animationEngine: "best-available", |
|||
animationOptions: {queue: !1, duration: 800}, |
|||
sortBy: "original-order", |
|||
sortAscending: !0, |
|||
resizesContainer: !0, |
|||
transformsEnabled: !0, |
|||
itemPositionDataEnabled: !1 |
|||
}, i.Isotope.prototype = { |
|||
_create: function (t) { |
|||
this.options = i.extend({}, i.Isotope.settings, t), this.styleQueue = [], this.elemCount = 0; |
|||
var s = this.element[0].style; |
|||
this.originalStyle = {}; |
|||
var e = w.slice(0); |
|||
for (var n in this.options.containerStyle) e.push(n); |
|||
for (var o = 0, r = e.length; r > o; o++) n = e[o], this.originalStyle[n] = s[n] || ""; |
|||
this.element.css(this.options.containerStyle), this._updateAnimationEngine(), this._updateUsingTransforms(); |
|||
var a = { |
|||
"original-order": function (t, i) { |
|||
return i.elemCount++, i.elemCount |
|||
}, random: function () { |
|||
return Math.random() |
|||
} |
|||
}; |
|||
this.options.getSortData = i.extend(this.options.getSortData, a), this.reloadItems(), this.offset = { |
|||
left: parseInt(this.element.css("padding-left") || 0, 10), |
|||
top: parseInt(this.element.css("padding-top") || 0, 10) |
|||
}; |
|||
var h = this; |
|||
setTimeout(function () { |
|||
h.element.addClass(h.options.containerClass) |
|||
}, 0), this.options.resizable && C.bind("smartresize.isotope", function () { |
|||
h.resize() |
|||
}), this.element.delegate("." + this.options.hiddenClass, "click", function () { |
|||
return !1 |
|||
}) |
|||
}, _getAtoms: function (t) { |
|||
var i = this.options.itemSelector, s = i ? t.filter(i).add(t.find(i)) : t, e = {position: "absolute"}; |
|||
return s = s.filter(function (t, i) { |
|||
return 1 === i.nodeType |
|||
}), this.usingTransforms && (e.left = 0, e.top = 0), s.css(e).addClass(this.options.itemClass), this.updateSortData(s, !0), s |
|||
}, _init: function (t) { |
|||
this.$filteredAtoms = this._filter(this.$allAtoms), this._sort(), this.reLayout(t) |
|||
}, option: function (t) { |
|||
if (i.isPlainObject(t)) { |
|||
this.options = i.extend(!0, this.options, t); |
|||
var s; |
|||
for (var e in t) s = "_update" + r(e), this[s] && this[s]() |
|||
} |
|||
}, _updateAnimationEngine: function () { |
|||
var t, i = this.options.animationEngine.toLowerCase().replace(/[ _\-]/g, ""); |
|||
switch (i) { |
|||
case "css": |
|||
case "none": |
|||
t = !1; |
|||
break; |
|||
case "jquery": |
|||
t = !0; |
|||
break; |
|||
default: |
|||
t = !o.csstransitions |
|||
} |
|||
this.isUsingJQueryAnimation = t, this._updateUsingTransforms() |
|||
}, _updateTransformsEnabled: function () { |
|||
this._updateUsingTransforms() |
|||
}, _updateUsingTransforms: function () { |
|||
var t = this.usingTransforms = this.options.transformsEnabled && o.csstransforms && o.csstransitions && !this.isUsingJQueryAnimation; |
|||
t || (delete this.options.hiddenStyle.scale, delete this.options.visibleStyle.scale), this.getPositionStyles = t ? this._translate : this._positionAbs |
|||
}, _filter: function (t) { |
|||
var i = "" === this.options.filter ? "*" : this.options.filter; |
|||
if (!i) return t; |
|||
var s = this.options.hiddenClass, e = "." + s, n = t.filter(e), o = n; |
|||
if ("*" !== i) { |
|||
o = n.filter(i); |
|||
var r = t.not(e).not(i).addClass(s); |
|||
this.styleQueue.push({$el: r, style: this.options.hiddenStyle}) |
|||
} |
|||
return this.styleQueue.push({$el: o, style: this.options.visibleStyle}), o.removeClass(s), t.filter(i) |
|||
}, updateSortData: function (t, s) { |
|||
var e, n, o = this, r = this.options.getSortData; |
|||
t.each(function () { |
|||
e = i(this), n = {}; |
|||
for (var t in r) s || "original-order" !== t ? n[t] = r[t](e, o) : n[t] = i.data(this, "isotope-sort-data")[t]; |
|||
i.data(this, "isotope-sort-data", n) |
|||
}) |
|||
}, _sort: function () { |
|||
var t = this.options.sortBy, i = this._getSorter, s = this.options.sortAscending ? 1 : -1, |
|||
e = function (e, n) { |
|||
var o = i(e, t), r = i(n, t); |
|||
return o === r && "original-order" !== t && (o = i(e, "original-order"), r = i(n, "original-order")), (o > r ? 1 : r > o ? -1 : 0) * s |
|||
}; |
|||
this.$filteredAtoms.sort(e) |
|||
}, _getSorter: function (t, s) { |
|||
return i.data(t, "isotope-sort-data")[s] |
|||
}, _translate: function (t, i) { |
|||
return {translate: [t, i]} |
|||
}, _positionAbs: function (t, i) { |
|||
return {left: t, top: i} |
|||
}, _pushPosition: function (t, i, s) { |
|||
i = Math.round(i + this.offset.left), s = Math.round(s + this.offset.top); |
|||
var e = this.getPositionStyles(i, s); |
|||
this.styleQueue.push({ |
|||
$el: t, |
|||
style: e |
|||
}), this.options.itemPositionDataEnabled && t.data("isotope-item-position", {x: i, y: s}) |
|||
}, layout: function (t, i) { |
|||
var s = this.options.layoutMode; |
|||
if (this["_" + s + "Layout"](t), this.options.resizesContainer) { |
|||
var e = this["_" + s + "GetContainerSize"](); |
|||
this.styleQueue.push({$el: this.element, style: e}) |
|||
} |
|||
this._processStyleQueue(t, i), this.isLaidOut = !0 |
|||
}, _processStyleQueue: function (t, s) { |
|||
var e, n, r, a, h = this.isLaidOut && this.isUsingJQueryAnimation ? "animate" : "css", |
|||
l = this.options.animationOptions, u = this.options.onLayout; |
|||
if (n = function (t, i) { |
|||
i.$el[h](i.style, l) |
|||
}, this._isInserting && this.isUsingJQueryAnimation) n = function (t, i) { |
|||
e = i.$el.hasClass("no-transition") ? "css" : h, i.$el[e](i.style, l) |
|||
}; else if (s || u || l.complete) { |
|||
var c = !1, d = [s, u, l.complete], f = this; |
|||
if (r = !0, a = function () { |
|||
if (!c) { |
|||
for (var i, s = 0, e = d.length; e > s; s++) i = d[s], "function" == typeof i && i.call(f.element, t, f); |
|||
c = !0 |
|||
} |
|||
}, this.isUsingJQueryAnimation && "animate" === h) l.complete = a, r = !1; else if (o.csstransitions) { |
|||
for (var m, p = 0, v = this.styleQueue[0], _ = v && v.$el; !_ || !_.length;) { |
|||
if (m = this.styleQueue[p++], !m) return; |
|||
_ = m.$el |
|||
} |
|||
var A = parseFloat(getComputedStyle(_[0])[g]); |
|||
A > 0 && (n = function (t, i) { |
|||
i.$el[h](i.style, l).one(y, a) |
|||
}, r = !1) |
|||
} |
|||
} |
|||
i.each(this.styleQueue, n), r && a(), this.styleQueue = [] |
|||
}, resize: function () { |
|||
this["_" + this.options.layoutMode + "ResizeChanged"]() && this.reLayout() |
|||
}, reLayout: function (t) { |
|||
this["_" + this.options.layoutMode + "Reset"](), this.layout(this.$filteredAtoms, t) |
|||
}, addItems: function (t, i) { |
|||
var s = this._getAtoms(t); |
|||
this.$allAtoms = this.$allAtoms.add(s), i && i(s) |
|||
}, insert: function (t, i) { |
|||
this.element.append(t); |
|||
var s = this; |
|||
this.addItems(t, function (t) { |
|||
var e = s._filter(t); |
|||
s._addHideAppended(e), s._sort(), s.reLayout(), s._revealAppended(e, i) |
|||
}) |
|||
}, appended: function (t, i) { |
|||
var s = this; |
|||
this.addItems(t, function (t) { |
|||
s._addHideAppended(t), s.layout(t), s._revealAppended(t, i) |
|||
}) |
|||
}, _addHideAppended: function (t) { |
|||
this.$filteredAtoms = this.$filteredAtoms.add(t), t.addClass("no-transition"), this._isInserting = !0, this.styleQueue.push({ |
|||
$el: t, |
|||
style: this.options.hiddenStyle |
|||
}) |
|||
}, _revealAppended: function (t, i) { |
|||
var s = this; |
|||
setTimeout(function () { |
|||
t.removeClass("no-transition"), s.styleQueue.push({ |
|||
$el: t, |
|||
style: s.options.visibleStyle |
|||
}), s._isInserting = !1, s._processStyleQueue(t, i) |
|||
}, 10) |
|||
}, reloadItems: function () { |
|||
this.$allAtoms = this._getAtoms(this.element.children()) |
|||
}, remove: function (t, i) { |
|||
this.$allAtoms = this.$allAtoms.not(t), this.$filteredAtoms = this.$filteredAtoms.not(t); |
|||
var s = this, e = function () { |
|||
t.remove(), i && i.call(s.element) |
|||
}; |
|||
t.filter(":not(." + this.options.hiddenClass + ")").length ? (this.styleQueue.push({ |
|||
$el: t, |
|||
style: this.options.hiddenStyle |
|||
}), this._sort(), this.reLayout(e)) : e() |
|||
}, shuffle: function (t) { |
|||
this.updateSortData(this.$allAtoms), this.options.sortBy = "random", this._sort(), this.reLayout(t) |
|||
}, destroy: function () { |
|||
var t = this.usingTransforms, i = this.options; |
|||
this.$allAtoms.removeClass(i.hiddenClass + " " + i.itemClass).each(function () { |
|||
var i = this.style; |
|||
i.position = "", i.top = "", i.left = "", i.opacity = "", t && (i[l] = "") |
|||
}); |
|||
var s = this.element[0].style; |
|||
for (var e in this.originalStyle) s[e] = this.originalStyle[e]; |
|||
this.element.unbind(".isotope").undelegate("." + i.hiddenClass, "click").removeClass(i.containerClass).removeData("isotope"), C.unbind(".isotope") |
|||
}, _getSegments: function (t) { |
|||
var i, s = this.options.layoutMode, e = t ? "rowHeight" : "columnWidth", n = t ? "height" : "width", |
|||
o = t ? "rows" : "cols", a = this.element[n](), |
|||
h = this.options[s] && this.options[s][e] || this.$filteredAtoms["outer" + r(n)](!0) || a; |
|||
i = Math.floor(a / h), i = Math.max(i, 1), this[s][o] = i, this[s][e] = h |
|||
}, _checkIfSegmentsChanged: function (t) { |
|||
var i = this.options.layoutMode, s = t ? "rows" : "cols", e = this[i][s]; |
|||
return this._getSegments(t), this[i][s] !== e |
|||
}, _masonryReset: function () { |
|||
this.masonry = {}, this._getSegments(); |
|||
var t = this.masonry.cols; |
|||
for (this.masonry.colYs = []; t--;) this.masonry.colYs.push(0) |
|||
}, _masonryLayout: function (t) { |
|||
var s = this, e = s.masonry; |
|||
t.each(function () { |
|||
var t = i(this), n = Math.ceil(t.outerWidth(!0) / e.columnWidth); |
|||
if (n = Math.min(n, e.cols), 1 === n) s._masonryPlaceBrick(t, e.colYs); else { |
|||
var o, r, a = e.cols + 1 - n, h = []; |
|||
for (r = 0; a > r; r++) o = e.colYs.slice(r, r + n), h[r] = Math.max.apply(Math, o); |
|||
s._masonryPlaceBrick(t, h) |
|||
} |
|||
}) |
|||
}, _masonryPlaceBrick: function (t, i) { |
|||
for (var s = Math.min.apply(Math, i), e = 0, n = 0, o = i.length; o > n; n++) if (i[n] === s) { |
|||
e = n; |
|||
break |
|||
} |
|||
var r = this.masonry.columnWidth * e, a = s; |
|||
this._pushPosition(t, r, a); |
|||
var h = s + t.outerHeight(!0), l = this.masonry.cols + 1 - o; |
|||
for (n = 0; l > n; n++) this.masonry.colYs[e + n] = h |
|||
}, _masonryGetContainerSize: function () { |
|||
var t = Math.max.apply(Math, this.masonry.colYs); |
|||
return {height: t} |
|||
}, _masonryResizeChanged: function () { |
|||
return this._checkIfSegmentsChanged() |
|||
}, _fitRowsReset: function () { |
|||
this.fitRows = {x: 0, y: 0, height: 0} |
|||
}, _fitRowsLayout: function (t) { |
|||
var s = this, e = this.element.width(), n = this.fitRows; |
|||
t.each(function () { |
|||
var t = i(this), o = t.outerWidth(!0), r = t.outerHeight(!0); |
|||
0 !== n.x && o + n.x > e && (n.x = 0, n.y = n.height), s._pushPosition(t, n.x, n.y), n.height = Math.max(n.y + r, n.height), n.x += o |
|||
}) |
|||
}, _fitRowsGetContainerSize: function () { |
|||
return {height: this.fitRows.height} |
|||
}, _fitRowsResizeChanged: function () { |
|||
return !0 |
|||
}, _cellsByRowReset: function () { |
|||
this.cellsByRow = {index: 0}, this._getSegments(), this._getSegments(!0) |
|||
}, _cellsByRowLayout: function (t) { |
|||
var s = this, e = this.cellsByRow; |
|||
t.each(function () { |
|||
var t = i(this), n = e.index % e.cols, o = Math.floor(e.index / e.cols), |
|||
r = (n + .5) * e.columnWidth - t.outerWidth(!0) / 2, |
|||
a = (o + .5) * e.rowHeight - t.outerHeight(!0) / 2; |
|||
s._pushPosition(t, r, a), e.index++ |
|||
}) |
|||
}, _cellsByRowGetContainerSize: function () { |
|||
return {height: Math.ceil(this.$filteredAtoms.length / this.cellsByRow.cols) * this.cellsByRow.rowHeight + this.offset.top} |
|||
}, _cellsByRowResizeChanged: function () { |
|||
return this._checkIfSegmentsChanged() |
|||
}, _straightDownReset: function () { |
|||
this.straightDown = {y: 0} |
|||
}, _straightDownLayout: function (t) { |
|||
var s = this; |
|||
t.each(function (t) { |
|||
var e = i(this); |
|||
s._pushPosition(e, 0, s.straightDown.y), s.straightDown.y += e.outerHeight(!0) |
|||
}) |
|||
}, _straightDownGetContainerSize: function () { |
|||
return {height: this.straightDown.y} |
|||
}, _straightDownResizeChanged: function () { |
|||
return !0 |
|||
}, _masonryHorizontalReset: function () { |
|||
this.masonryHorizontal = {}, this._getSegments(!0); |
|||
var t = this.masonryHorizontal.rows; |
|||
for (this.masonryHorizontal.rowXs = []; t--;) this.masonryHorizontal.rowXs.push(0) |
|||
}, _masonryHorizontalLayout: function (t) { |
|||
var s = this, e = s.masonryHorizontal; |
|||
t.each(function () { |
|||
var t = i(this), n = Math.ceil(t.outerHeight(!0) / e.rowHeight); |
|||
if (n = Math.min(n, e.rows), 1 === n) s._masonryHorizontalPlaceBrick(t, e.rowXs); else { |
|||
var o, r, a = e.rows + 1 - n, h = []; |
|||
for (r = 0; a > r; r++) o = e.rowXs.slice(r, r + n), h[r] = Math.max.apply(Math, o); |
|||
s._masonryHorizontalPlaceBrick(t, h) |
|||
} |
|||
}) |
|||
}, _masonryHorizontalPlaceBrick: function (t, i) { |
|||
for (var s = Math.min.apply(Math, i), e = 0, n = 0, o = i.length; o > n; n++) if (i[n] === s) { |
|||
e = n; |
|||
break |
|||
} |
|||
var r = s, a = this.masonryHorizontal.rowHeight * e; |
|||
this._pushPosition(t, r, a); |
|||
var h = s + t.outerWidth(!0), l = this.masonryHorizontal.rows + 1 - o; |
|||
for (n = 0; l > n; n++) this.masonryHorizontal.rowXs[e + n] = h |
|||
}, _masonryHorizontalGetContainerSize: function () { |
|||
var t = Math.max.apply(Math, this.masonryHorizontal.rowXs); |
|||
return {width: t} |
|||
}, _masonryHorizontalResizeChanged: function () { |
|||
return this._checkIfSegmentsChanged(!0) |
|||
}, _fitColumnsReset: function () { |
|||
this.fitColumns = {x: 0, y: 0, width: 0} |
|||
}, _fitColumnsLayout: function (t) { |
|||
var s = this, e = this.element.height(), n = this.fitColumns; |
|||
t.each(function () { |
|||
var t = i(this), o = t.outerWidth(!0), r = t.outerHeight(!0); |
|||
0 !== n.y && r + n.y > e && (n.x = n.width, n.y = 0), s._pushPosition(t, n.x, n.y), n.width = Math.max(n.x + o, n.width), n.y += r |
|||
}) |
|||
}, _fitColumnsGetContainerSize: function () { |
|||
return {width: this.fitColumns.width} |
|||
}, _fitColumnsResizeChanged: function () { |
|||
return !0 |
|||
}, _cellsByColumnReset: function () { |
|||
this.cellsByColumn = {index: 0}, this._getSegments(), this._getSegments(!0) |
|||
}, _cellsByColumnLayout: function (t) { |
|||
var s = this, e = this.cellsByColumn; |
|||
t.each(function () { |
|||
var t = i(this), n = Math.floor(e.index / e.rows), o = e.index % e.rows, |
|||
r = (n + .5) * e.columnWidth - t.outerWidth(!0) / 2, |
|||
a = (o + .5) * e.rowHeight - t.outerHeight(!0) / 2; |
|||
s._pushPosition(t, r, a), e.index++ |
|||
}) |
|||
}, _cellsByColumnGetContainerSize: function () { |
|||
return {width: Math.ceil(this.$filteredAtoms.length / this.cellsByColumn.rows) * this.cellsByColumn.columnWidth} |
|||
}, _cellsByColumnResizeChanged: function () { |
|||
return this._checkIfSegmentsChanged(!0) |
|||
}, _straightAcrossReset: function () { |
|||
this.straightAcross = {x: 0} |
|||
}, _straightAcrossLayout: function (t) { |
|||
var s = this; |
|||
t.each(function (t) { |
|||
var e = i(this); |
|||
s._pushPosition(e, s.straightAcross.x, 0), s.straightAcross.x += e.outerWidth(!0) |
|||
}) |
|||
}, _straightAcrossGetContainerSize: function () { |
|||
return {width: this.straightAcross.x} |
|||
}, _straightAcrossResizeChanged: function () { |
|||
return !0 |
|||
} |
|||
}, i.fn.imagesLoaded = function (t) { |
|||
function s() { |
|||
t.call(n, o) |
|||
} |
|||
|
|||
function e(t) { |
|||
var n = t.target; |
|||
n.src !== a && -1 === i.inArray(n, h) && (h.push(n), --r <= 0 && (setTimeout(s), o.unbind(".imagesLoaded", e))) |
|||
} |
|||
|
|||
var n = this, o = n.find("img").add(n.filter("img")), r = o.length, |
|||
a = "", h = []; |
|||
return r || s(), o.bind("load.imagesLoaded error.imagesLoaded", e).each(function () { |
|||
var t = this.src; |
|||
this.src = a, this.src = t |
|||
}), n |
|||
}; |
|||
var z = function (i) { |
|||
t.console && t.console.error(i) |
|||
}; |
|||
i.fn.isotope = function (t, s) { |
|||
if ("string" == typeof t) { |
|||
var e = Array.prototype.slice.call(arguments, 1); |
|||
this.each(function () { |
|||
var s = i.data(this, "isotope"); |
|||
return s ? i.isFunction(s[t]) && "_" !== t.charAt(0) ? void s[t].apply(s, e) : void z("no such method '" + t + "' for isotope instance") : void z("cannot call methods on isotope prior to initialization; attempted to call method '" + t + "'") |
|||
}) |
|||
} else this.each(function () { |
|||
var e = i.data(this, "isotope"); |
|||
e ? (e.option(t), e._init(s)) : i.data(this, "isotope", new i.Isotope(t, this, s)) |
|||
}); |
|||
return this |
|||
} |
|||
}(window, jQuery); |
|||
let $mainNav = $("#mainNav"); |
|||
let $body = $("body"); |
|||
let $scroll_to_top = $("#scroll-to-top"); |
|||
// 页面顶部时,导航栏背景透明
|
|||
let toggle_flag = true; |
|||
$('.navbar-toggler').click(() => { |
|||
let all_class = $mainNav.attr('class'); |
|||
if (all_class.indexOf('navbar-shrink') === -1) { |
|||
$mainNav.addClass('navbar-shrink'); |
|||
} else { |
|||
if ($mainNav.offset().top <= 10) { |
|||
$mainNav.removeClass("navbar-shrink"); |
|||
} |
|||
} |
|||
toggle_flag = false; |
|||
}); |
|||
// 移动端点击空白处,隐藏菜单
|
|||
$body.click(() => { |
|||
$('.navbar-collapse').collapse('hide'); |
|||
if (toggle_flag) { // 阻止事件冒泡
|
|||
if ($mainNav.offset().top <= 10) { |
|||
$mainNav.removeClass("navbar-shrink"); |
|||
} |
|||
} |
|||
toggle_flag = true; |
|||
}); |
|||
// 移动端点击菜单后,隐藏菜单
|
|||
$('.js-scroll-trigger').click(() => { |
|||
$('.navbar-collapse').collapse('hide'); |
|||
}); |
|||
// 导航栏自动隐藏
|
|||
let previousTop = 0; |
|||
$(window).scroll(() => { |
|||
let currentTop = $(window).scrollTop(); |
|||
if (currentTop - previousTop < -10) { |
|||
// 下划
|
|||
$mainNav.removeClass("show-none"); |
|||
previousTop = currentTop; |
|||
} else if (currentTop - previousTop > 10) { |
|||
// 上划
|
|||
$mainNav.addClass("show-none"); |
|||
$('.navbar-collapse').collapse('hide'); |
|||
previousTop = currentTop; |
|||
} |
|||
if (currentTop < 60) { |
|||
// 首页常显示
|
|||
$mainNav.removeClass("show-none"); |
|||
} |
|||
}); |
|||
// 非顶部刷新时,设置导航栏不透明
|
|||
let navbarCollapse = () => { |
|||
if ($mainNav.offset().top > 10) { |
|||
$mainNav.addClass("navbar-shrink"); |
|||
} else { |
|||
$mainNav.removeClass("navbar-shrink"); |
|||
} |
|||
}; |
|||
navbarCollapse(); |
|||
$(window).scroll(navbarCollapse); |
|||
// 底部滚动
|
|||
$(window).scroll(() => { |
|||
if ($(window).scrollTop() < 100) { |
|||
$scroll_to_top.removeClass('show'); |
|||
} else { |
|||
$scroll_to_top.addClass('show'); |
|||
} |
|||
}); |
|||
$scroll_to_top.click(function (e) { |
|||
e.preventDefault() |
|||
$('html,body').animate({ |
|||
scrollTop: 0 |
|||
}, 700); |
|||
}); |
|||
// 主题切换
|
|||
let like_color = 'darkorange'; |
|||
let like_color0 = '#888888'; |
|||
if ($('body').hasClass('body_dark')) { |
|||
$('.article-single').addClass('body_dark'); |
|||
like_color = '#68a7eb'; |
|||
like_color0 = '#777777'; |
|||
} |
|||
let set_light = () => { |
|||
$('.body_dark').removeClass('body_dark'); |
|||
$('#logo').attr('src', 'logo/logo.png'); |
|||
like_color = 'darkorange'; |
|||
like_color0 = '#888888'; |
|||
let headHTML = document.getElementsByTagName('head')[0].innerHTML; |
|||
headHTML = headHTML.replace(/1A1D24/, "E4EBF8"); |
|||
document.getElementsByTagName('head')[0].innerHTML = headHTML; |
|||
}; |
|||
let set_dark = () => { |
|||
$('#logo').attr('src', 'logo/logo-dark.png'); |
|||
$('body').addClass('body_dark'); |
|||
$('.section-title h3').addClass('body_dark'); |
|||
$('#mainNav').addClass('body_dark'); |
|||
$('#switch_dark').addClass('body_dark'); |
|||
$('.navbar-toggler').addClass('body_dark'); |
|||
$('.blog').addClass('body_dark'); |
|||
$('.section').addClass('body_dark'); |
|||
$('.section button').addClass('body_dark'); |
|||
$('#home').addClass('body_dark'); |
|||
$('#notes .services-inner-box').addClass('body_dark'); |
|||
$('#api .services-inner-box').addClass('body_dark'); |
|||
$('#opus .opus-single').addClass('body_dark'); |
|||
$('#demo .demo-single').addClass('body_dark'); |
|||
$('#contact .contact_form').addClass('body_dark'); |
|||
$('.article-single').addClass('body_dark'); |
|||
like_color = '#68a7eb'; |
|||
like_color0 = '#777777'; |
|||
let headHTML = document.getElementsByTagName('head')[0].innerHTML; |
|||
headHTML = headHTML.replace(/E4EBF8/, "1A1D24"); |
|||
document.getElementsByTagName('head')[0].innerHTML = headHTML; |
|||
}; |
|||
$('.toggle').click(function (e) { |
|||
$(this).toggleClass('toggle--on') |
|||
.toggleClass('toggle--off') |
|||
.addClass('toggle--moving'); |
|||
setTimeout(() => { |
|||
$(this).removeClass('toggle--moving'); |
|||
}, 200); |
|||
let is_dark = $('body').hasClass('body_dark'); |
|||
$('.clock div').css('transition', 'all .3s ease-in-out'); |
|||
setTimeout(() => { |
|||
$('.clock div.minutes').css('transition', 'none'); |
|||
$('.clock div.hours').css('transition', 'none'); |
|||
}, 400); |
|||
setTimeout(() => { |
|||
if (!is_dark) { |
|||
set_dark(); |
|||
} else { |
|||
set_light(); |
|||
} |
|||
}, 100); |
|||
$.ajax({ |
|||
url: '/toggle_dark/', |
|||
type: 'post', |
|||
data: { |
|||
'csrfmiddlewaretoken': $('[name="csrfmiddlewaretoken"]').val(), |
|||
'is_dark': is_dark, |
|||
}, |
|||
success: () => { |
|||
} |
|||
}) |
|||
}); |
|||
@ -0,0 +1 @@ |
|||
window.onresize=(()=>{$(window).width()>=768&&$(".button-group button.active").click()});let $grid_note=$(".note-list").isotope({itemSelector:".note-grid"});$(".note-menu").on("click","button",function(){$(this).addClass("active").siblings().removeClass("active");let t=$(this).attr("data-filter");$grid_note.isotope({filter:t})});let $grid_api=$(".api-list").isotope({itemSelector:".api-grid"});$(".api-menu").on("click","button",function(){$(this).addClass("active").siblings().removeClass("active");let t=$(this).attr("data-filter");$grid_api.isotope({filter:t})}); |
|||
@ -0,0 +1,30 @@ |
|||
// 桌面端窗口自适应
|
|||
window.onresize = () => { |
|||
if ($(window).width() >= 768) { |
|||
$('.button-group button.active').click(); |
|||
} |
|||
}; |
|||
// 笔记分类
|
|||
let $grid_note = $('.note-list').isotope({ |
|||
itemSelector: '.note-grid', |
|||
}); |
|||
$('.note-menu').on('click', 'button', function () { |
|||
$(this).addClass('active').siblings().removeClass('active'); |
|||
let filterValue = $(this).attr('data-filter'); |
|||
$grid_note.isotope({ |
|||
filter: filterValue, |
|||
}); |
|||
}); |
|||
|
|||
// API分类
|
|||
let $grid_api = $('.api-list').isotope({ |
|||
itemSelector: '.api-grid', |
|||
}); |
|||
$('.api-menu').on('click', 'button', function () { |
|||
$(this).addClass('active').siblings().removeClass('active'); |
|||
let filterValue = $(this).attr('data-filter'); |
|||
$grid_api.isotope({ |
|||
filter: filterValue, |
|||
}); |
|||
}); |
|||
|
|||
|
After Width: | Height: | Size: 5.9 KiB |
|
After Width: | Height: | Size: 6.6 KiB |
Loading…
Reference in new issue