2019-11-13 08:06:51 +00:00
|
|
|
{{ if .Site.Params.custom_js }}
|
|
|
|
{{ range .Site.Params.custom_js }}
|
2019-11-06 16:47:35 +00:00
|
|
|
{{ $custom_template := resources.Get . }}
|
|
|
|
{{ if $custom_template }}
|
|
|
|
{{ $custom_js := $custom_template | resources.Minify | resources.Fingerprint }}
|
|
|
|
<script defer src="{{ $custom_js.RelPermalink }}"></script>
|
|
|
|
{{ end }}
|
2019-11-13 08:06:51 +00:00
|
|
|
{{ end }}
|
2019-11-27 01:16:53 +00:00
|
|
|
{{ end }}
|
|
|
|
|
2020-01-29 00:55:11 +00:00
|
|
|
{{ $enquire := resources.Get "js/enquire.min.js" | resources.Fingerprint }}
|
|
|
|
<script src="{{ $enquire.RelPermalink }}"></script>
|
|
|
|
{{ $lazysizes := resources.Get "js/lazysizes.min.js" | resources.Fingerprint }}
|
|
|
|
<script defer src="{{ $lazysizes.RelPermalink }}"></script>
|
2019-12-09 14:00:51 +00:00
|
|
|
{{ $fuse := resources.Get "js/fuse.min.js" | resources.Fingerprint }}
|
|
|
|
<script defer src="{{ $fuse.RelPermalink }}"></script>
|
2020-01-06 16:41:38 +00:00
|
|
|
{{ $getParents := resources.Get "js/helper/getParents.js" | resources.Minify | resources.Fingerprint }}
|
|
|
|
<script defer src="{{ $getParents.RelPermalink }}"></script>
|
|
|
|
{{ $fadeinout := resources.Get "js/helper/fadeinout.js" | resources.Minify | resources.Fingerprint }}
|
|
|
|
<script defer src="{{ $fadeinout.RelPermalink }}"></script>
|
2020-01-22 08:31:10 +00:00
|
|
|
{{ $closest := resources.Get "js/helper/closest.js" | resources.Minify }}
|
|
|
|
<script defer src="{{ $closest.RelPermalink }}"></script>
|
|
|
|
|
2019-11-27 01:16:53 +00:00
|
|
|
<script>
|
2020-01-06 16:41:38 +00:00
|
|
|
"use strict";
|
|
|
|
|
2020-01-23 13:00:38 +00:00
|
|
|
// ========================== poiyfill ==========================
|
|
|
|
// forEach
|
|
|
|
if (window.NodeList && !NodeList.prototype.forEach) {
|
|
|
|
NodeList.prototype.forEach = Array.prototype.forEach;
|
|
|
|
}
|
|
|
|
|
|
|
|
// includes
|
|
|
|
if (!String.prototype.includes) {
|
|
|
|
String.prototype.includes = function (search, start) {
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
if (search instanceof RegExp) {
|
|
|
|
throw TypeError('first argument must not be a RegExp');
|
|
|
|
}
|
|
|
|
if (start === undefined) { start = 0; }
|
|
|
|
return this.indexOf(search, start) !== -1;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
// append
|
|
|
|
Document.prototype.append = Element.prototype.append = function append() {
|
|
|
|
this.appendChild(_mutation(arguments));
|
|
|
|
};
|
|
|
|
function _mutation(nodes) {
|
|
|
|
if (!nodes.length) {
|
|
|
|
throw new Error('DOM Exception 8');
|
|
|
|
} else if (nodes.length === 1) {
|
|
|
|
return typeof nodes[0] === 'string' ? document.createTextNode(nodes[0]) : nodes[0];
|
|
|
|
} else {
|
|
|
|
var
|
|
|
|
fragment = document.createDocumentFragment(),
|
|
|
|
length = nodes.length,
|
|
|
|
index = -1,
|
|
|
|
node;
|
|
|
|
|
|
|
|
while (++index < length) {
|
|
|
|
node = nodes[index];
|
|
|
|
|
|
|
|
fragment.appendChild(typeof node === 'string' ? document.createTextNode(node) : node);
|
|
|
|
}
|
|
|
|
|
|
|
|
return fragment;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// startsWith
|
|
|
|
if (!String.prototype.startsWith) {
|
|
|
|
String.prototype.startsWith = function (searchString, position) {
|
|
|
|
position = position || 0;
|
|
|
|
return this.indexOf(searchString, position) === position;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
// ===============================================================
|
|
|
|
|
2020-02-05 17:23:27 +00:00
|
|
|
{{ $permalink := .Permalink }}
|
|
|
|
var permalink = JSON.parse({{ $permalink | jsonify }});
|
2020-01-23 13:00:38 +00:00
|
|
|
|
2020-01-06 16:41:38 +00:00
|
|
|
document.addEventListener('DOMContentLoaded', function () {
|
2020-01-22 08:31:10 +00:00
|
|
|
// ============================ tab ============================
|
|
|
|
document.querySelectorAll('.tab') ?
|
|
|
|
document.querySelectorAll('.tab').forEach(function(elem, idx) {
|
|
|
|
var containerId = elem.getAttribute('id');
|
|
|
|
var containerElem = elem;
|
|
|
|
var tabLinks = elem.querySelectorAll('.tab__link');
|
|
|
|
var tabContents = elem.querySelectorAll('.tab__content');
|
|
|
|
var ids = [];
|
|
|
|
|
|
|
|
tabLinks && tabLinks.length > 0 ?
|
|
|
|
tabLinks.forEach(function(link, index, self) {
|
|
|
|
link.onclick = function(e) {
|
|
|
|
for (var i = 0; i < self.length; i++) {
|
|
|
|
if (index === parseInt(i, 10)) {
|
|
|
|
if (!self[i].classList.contains('active')) {
|
|
|
|
self[i].classList.add('active');
|
|
|
|
tabContents[i].style.display = 'block';
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
self[i].classList.remove('active');
|
|
|
|
tabContents[i].style.display = 'none';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}) : null;
|
|
|
|
}) : null;
|
|
|
|
// =============================================================
|
|
|
|
|
|
|
|
|
2020-01-23 17:46:03 +00:00
|
|
|
// ========================== codetab ==========================
|
|
|
|
document.querySelectorAll('.codetab') ?
|
|
|
|
document.querySelectorAll('.codetab').forEach(function(elem, idx) {
|
|
|
|
var containerId = elem.getAttribute('id');
|
|
|
|
var containerElem = elem;
|
|
|
|
var codetabLinks = elem.querySelectorAll('.codetab__link');
|
|
|
|
var codetabContents = elem.querySelectorAll('.codetab__content');
|
|
|
|
var ids = [];
|
|
|
|
|
|
|
|
codetabLinks && codetabLinks.length > 0 ?
|
|
|
|
codetabLinks.forEach(function(link, index, self) {
|
|
|
|
link.onclick = function(e) {
|
|
|
|
for (var i = 0; i < self.length; i++) {
|
|
|
|
if (index === parseInt(i, 10)) {
|
|
|
|
if (!self[i].classList.contains('active')) {
|
|
|
|
self[i].classList.add('active');
|
|
|
|
codetabContents[i].style.display = 'block';
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
self[i].classList.remove('active');
|
|
|
|
codetabContents[i].style.display = 'none';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}) : null;
|
|
|
|
}) : null;
|
|
|
|
// =============================================================
|
|
|
|
|
|
|
|
|
2020-01-06 16:41:38 +00:00
|
|
|
// ========================= go to top =========================
|
|
|
|
var gttBtn = document.getElementById("gtt");
|
|
|
|
gttBtn.style.display = "none";
|
|
|
|
gttBtn.addEventListener('click', function () {
|
2020-01-23 13:00:38 +00:00
|
|
|
if (window.document.documentMode) {
|
|
|
|
document.documentElement.scrollTop = 0;
|
|
|
|
} else {
|
|
|
|
scrollToTop(250);
|
|
|
|
}
|
2020-01-06 16:41:38 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
function scrollToTop(scrollDuration) {
|
|
|
|
var scrollStep = -window.scrollY / (scrollDuration / 15);
|
|
|
|
var scrollInterval = setInterval(function () {
|
|
|
|
if (window.scrollY != 0) {
|
|
|
|
window.scrollBy(0, scrollStep);
|
|
|
|
}
|
|
|
|
else clearInterval(scrollInterval);
|
|
|
|
}, 15);
|
|
|
|
}
|
|
|
|
|
|
|
|
var scrollFunction = function () {
|
|
|
|
if (document.body.scrollTop > 250 || document.documentElement.scrollTop > 250) {
|
|
|
|
gttBtn.style.display = "block";
|
|
|
|
} else {
|
|
|
|
gttBtn.style.display = "none";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// ============================================================
|
|
|
|
|
|
|
|
|
2020-01-07 07:30:51 +00:00
|
|
|
// ========================== expand ==========================
|
|
|
|
var expandBtn = document.querySelectorAll('.expand__button');
|
|
|
|
|
|
|
|
for (let i = 0; i < expandBtn.length; i++) {
|
|
|
|
expandBtn[i].addEventListener("click", function () {
|
|
|
|
var content = this.nextElementSibling;
|
|
|
|
if (content.style.maxHeight) {
|
|
|
|
content.style.maxHeight = null;
|
|
|
|
this.querySelector('svg').classList.add('expand-icon__right');
|
|
|
|
this.querySelector('svg').classList.remove('expand-icon__down');
|
|
|
|
} else {
|
|
|
|
content.style.maxHeight = content.scrollHeight + "px";
|
|
|
|
this.querySelector('svg').classList.remove('expand-icon__right');
|
|
|
|
this.querySelector('svg').classList.add('expand-icon__down');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
// ============================================================
|
|
|
|
|
|
|
|
|
2020-01-06 16:41:38 +00:00
|
|
|
// ========================== scroll ==========================
|
|
|
|
var lastScrollTop = window.pageYOffset || document.documentElement.scrollTop;
|
|
|
|
var tocElem = document.querySelector('.toc');
|
2020-01-07 07:30:51 +00:00
|
|
|
var tableOfContentsElem = tocElem ? tocElem.querySelector('#TableOfContents') : null;
|
2020-01-06 16:41:38 +00:00
|
|
|
var toggleTocElem = document.getElementById('toggle-toc');
|
|
|
|
var singleContentsElem = document.querySelector('.single__contents');
|
|
|
|
var navbar = document.querySelector('.navbar');
|
2020-01-23 19:25:57 +00:00
|
|
|
var tocFlexbox = document.querySelector('.toc__flexbox');
|
|
|
|
var tocFlexboxOuter = document.querySelector('.toc__flexbox--outer');
|
2020-01-25 08:18:02 +00:00
|
|
|
var expandContents = document.querySelectorAll('.expand__content');
|
|
|
|
var boxContents = document.querySelectorAll('.box');
|
2020-01-24 07:05:56 +00:00
|
|
|
var notAllowedTitleIds = null;
|
|
|
|
|
2020-01-31 06:06:30 +00:00
|
|
|
{{ $tocFolding := $.Param "tocFolding" }}
|
|
|
|
var tocFolding = JSON.parse({{ $tocFolding | jsonify }});
|
|
|
|
|
2020-01-25 08:18:02 +00:00
|
|
|
// tab
|
2020-01-24 07:05:56 +00:00
|
|
|
singleContentsElem && singleContentsElem.querySelectorAll(".tab") ?
|
|
|
|
singleContentsElem.querySelectorAll(".tab").forEach(function (elem) {
|
|
|
|
elem.querySelectorAll("h1, h2, h3, h4, h5, h6").forEach(function (element) {
|
|
|
|
notAllowedTitleIds = Array.isArray(notAllowedTitleIds) ?
|
|
|
|
notAllowedTitleIds.concat(element.getAttribute('id')) :
|
|
|
|
[element.getAttribute('id')];
|
|
|
|
});
|
|
|
|
}) : null;
|
2020-01-25 08:18:02 +00:00
|
|
|
|
|
|
|
// expand
|
|
|
|
expandContents ? expandContents.forEach(function(elem) {
|
|
|
|
elem.querySelectorAll("h1, h2, h3, h4, h5, h6").forEach(function (element) {
|
|
|
|
notAllowedTitleIds = Array.isArray(notAllowedTitleIds) ?
|
|
|
|
notAllowedTitleIds.concat(element.getAttribute('id')) :
|
|
|
|
[element.getAttribute('id')];
|
|
|
|
});
|
|
|
|
}) : null;
|
|
|
|
|
|
|
|
// box
|
|
|
|
boxContents ? boxContents.forEach(function(elem) {
|
|
|
|
elem.querySelectorAll("h1, h2, h3, h4, h5, h6").forEach(function (element) {
|
|
|
|
notAllowedTitleIds = Array.isArray(notAllowedTitleIds) ?
|
|
|
|
notAllowedTitleIds.concat(element.getAttribute('id')) :
|
|
|
|
[element.getAttribute('id')];
|
|
|
|
});
|
|
|
|
}) : null;
|
|
|
|
|
2020-01-24 07:05:56 +00:00
|
|
|
|
2020-01-06 16:41:38 +00:00
|
|
|
window.onscroll = function () {
|
|
|
|
scrollFunction();
|
|
|
|
|
|
|
|
var st = window.pageYOffset || document.documentElement.scrollTop;
|
|
|
|
if (st > lastScrollTop) { // scroll down
|
|
|
|
if (st < 250) {
|
|
|
|
gttBtn.style.display = "none";
|
|
|
|
} else {
|
|
|
|
gttBtn.style.display = "block";
|
|
|
|
}
|
|
|
|
|
|
|
|
if (st < 45) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!navbar.classList.contains('navbar--hide')) {
|
|
|
|
navbar.classList.add('navbar--hide');
|
|
|
|
} else if (navbar.classList.contains('navbar--show')) {
|
|
|
|
navbar.classList.remove('navbar--show');
|
|
|
|
}
|
2020-01-23 19:25:57 +00:00
|
|
|
|
|
|
|
if (singleContentsElem) {
|
|
|
|
if (singleContentsElem.querySelectorAll("h1, h2, h3, h4, h5, h6").length > 0) {
|
|
|
|
singleContentsElem.querySelectorAll("h1, h2, h3, h4, h5, h6").forEach(function (elem) {
|
|
|
|
if (toggleTocElem && !toggleTocElem.checked) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2020-01-24 07:05:56 +00:00
|
|
|
if (notAllowedTitleIds && notAllowedTitleIds.includes(elem.getAttribute('id'))) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2020-01-23 19:25:57 +00:00
|
|
|
if (document.documentElement.scrollTop >= elem.offsetTop) {
|
|
|
|
if (tableOfContentsElem) {
|
|
|
|
var id = elem.getAttribute('id');
|
|
|
|
tocElem.querySelectorAll('a').forEach(function (elem) {
|
|
|
|
elem.classList.remove('active');
|
|
|
|
});
|
|
|
|
tocElem.querySelector('a[href="#' + id + '"]') ?
|
|
|
|
tocElem.querySelector('a[href="#' + id + '"]').classList.add('active') : null;
|
|
|
|
|
2020-01-31 06:06:30 +00:00
|
|
|
if (false === tocFolding) {
|
|
|
|
|
|
|
|
} else {
|
|
|
|
tableOfContentsElem.querySelectorAll('ul') ?
|
|
|
|
tableOfContentsElem.querySelectorAll('ul').forEach(function (rootUl) {
|
|
|
|
rootUl.querySelectorAll('li').forEach(function (liElem) {
|
|
|
|
liElem.querySelectorAll('ul').forEach(function (ulElem) {
|
|
|
|
ulElem.style.display = 'none';
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}) : null;
|
|
|
|
}
|
2020-01-23 19:25:57 +00:00
|
|
|
|
|
|
|
var curElem = tableOfContentsElem.querySelector("[href='#" + id + "']");
|
|
|
|
if (curElem && curElem.nextElementSibling) {
|
|
|
|
curElem.nextElementSibling.style.display = 'block';
|
|
|
|
}
|
|
|
|
getParents(curElem, 'ul') ?
|
|
|
|
getParents(curElem, 'ul').forEach(function (elem) {
|
|
|
|
elem.style.display = 'block';
|
|
|
|
}) : null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
if (tocFlexbox) {
|
|
|
|
tocFlexbox.setAttribute('data-position', '');
|
|
|
|
if (!tocFlexbox.classList.contains('hide')) {
|
|
|
|
tocFlexbox.classList.add('hide');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (tocFlexboxOuter) {
|
|
|
|
tocFlexboxOuter.setAttribute('data-position', '');
|
|
|
|
if (!tocFlexboxOuter.classList.contains('hide')) {
|
|
|
|
tocFlexboxOuter.classList.add('hide');
|
2020-01-07 07:30:51 +00:00
|
|
|
}
|
2020-01-06 16:41:38 +00:00
|
|
|
}
|
|
|
|
}
|
2020-01-23 19:25:57 +00:00
|
|
|
}
|
2020-01-06 16:41:38 +00:00
|
|
|
} else { // scroll up
|
|
|
|
if (st < 250) {
|
|
|
|
gttBtn.style.display = "none";
|
|
|
|
}
|
|
|
|
|
|
|
|
if (navbar.classList.contains('navbar--hide')) {
|
|
|
|
navbar.classList.remove('navbar--hide');
|
|
|
|
} else if (!navbar.classList.contains('navbar--show')) {
|
|
|
|
navbar.classList.add('navbar--show');
|
|
|
|
}
|
|
|
|
|
2020-01-23 19:25:57 +00:00
|
|
|
if (singleContentsElem) {
|
|
|
|
if (singleContentsElem.querySelectorAll("h1, h2, h3, h4, h5, h6").length > 0) {
|
|
|
|
singleContentsElem.querySelectorAll("h1, h2, h3, h4, h5, h6").forEach(function (elem) {
|
|
|
|
if (toggleTocElem && !toggleTocElem.checked) {
|
|
|
|
return null;
|
|
|
|
}
|
2020-01-24 07:05:56 +00:00
|
|
|
|
|
|
|
if (notAllowedTitleIds && notAllowedTitleIds.includes(elem.getAttribute('id'))) {
|
|
|
|
return null;
|
|
|
|
}
|
2020-01-06 16:41:38 +00:00
|
|
|
|
2020-01-23 19:25:57 +00:00
|
|
|
if (document.documentElement.scrollTop >= elem.offsetTop) {
|
|
|
|
if (tableOfContentsElem) {
|
|
|
|
var id = elem.getAttribute('id');
|
|
|
|
tocElem.querySelectorAll('a').forEach(function (elem) {
|
|
|
|
elem.classList.remove('active');
|
|
|
|
});
|
|
|
|
tocElem.querySelector('a[href="#' + id + '"]') ?
|
|
|
|
tocElem.querySelector('a[href="#' + id + '"]').classList.add('active') : null;
|
|
|
|
|
2020-01-31 06:06:30 +00:00
|
|
|
if (false === tocFolding) {
|
|
|
|
|
|
|
|
} else {
|
|
|
|
tableOfContentsElem.querySelectorAll('ul') ?
|
|
|
|
tableOfContentsElem.querySelectorAll('ul').forEach(function (rootUl) {
|
|
|
|
rootUl.querySelectorAll('li').forEach(function (liElem) {
|
|
|
|
liElem.querySelectorAll('ul').forEach(function (ulElem) {
|
|
|
|
ulElem.style.display = 'none';
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}) : null;
|
|
|
|
}
|
2020-01-06 16:41:38 +00:00
|
|
|
|
2020-01-23 19:25:57 +00:00
|
|
|
var curElem = tableOfContentsElem.querySelector("[href='#" + id + "']");
|
|
|
|
if (curElem && curElem.nextElementSibling) {
|
|
|
|
curElem.nextElementSibling.style.display = 'block';
|
|
|
|
}
|
|
|
|
getParents(curElem, 'ul') ?
|
|
|
|
getParents(curElem, 'ul').forEach(function (elem) {
|
|
|
|
elem.style.display = 'block';
|
|
|
|
}) : null;
|
|
|
|
}
|
2020-01-07 07:30:51 +00:00
|
|
|
}
|
2020-01-23 19:25:57 +00:00
|
|
|
});
|
|
|
|
} else {
|
|
|
|
if (tocFlexbox && !tocFlexbox.classList.contains('hide')) {
|
|
|
|
tocFlexbox.classList.add('hide');
|
|
|
|
}
|
|
|
|
if (tocFlexboxOuter && !tocFlexboxOuter.classList.contains('hide')) {
|
|
|
|
tocFlexboxOuter.classList.add('hide');
|
2020-01-06 16:41:38 +00:00
|
|
|
}
|
|
|
|
}
|
2020-01-23 19:25:57 +00:00
|
|
|
|
|
|
|
}
|
2020-01-06 16:41:38 +00:00
|
|
|
|
|
|
|
if (tableOfContentsElem && document.documentElement.scrollTop < 250) {
|
2020-01-31 06:06:30 +00:00
|
|
|
if (false === tocFolding) {
|
|
|
|
|
|
|
|
} else {
|
|
|
|
tableOfContentsElem.querySelector('ul') ?
|
|
|
|
tableOfContentsElem.querySelector('ul').querySelectorAll('li').forEach(function (liElem) {
|
|
|
|
liElem.querySelectorAll('ul').forEach(function (ulElem) {
|
|
|
|
ulElem.style.display = 'none';
|
|
|
|
});
|
|
|
|
}) : null;
|
|
|
|
}
|
2020-01-06 16:41:38 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
lastScrollTop = st <= 0 ? 0 : st;
|
|
|
|
};
|
|
|
|
// ============================================================
|
|
|
|
|
|
|
|
|
|
|
|
// ========================== navbar ==========================
|
|
|
|
var navbarBurgerElem = document.querySelector('.navbar__burger');
|
|
|
|
var navbarMenuElem = document.querySelector('.navbar__menu');
|
|
|
|
navbarBurgerElem ?
|
|
|
|
navbarBurgerElem.addEventListener('click', function () {
|
|
|
|
if (navbarBurgerElem.classList.contains('is-active')) {
|
|
|
|
navbarBurgerElem.classList.remove('is-active');
|
|
|
|
navbarMenuElem.classList.remove('is-active');
|
|
|
|
} else {
|
|
|
|
navbarBurgerElem.classList.add('is-active');
|
|
|
|
navbarMenuElem.classList.add('is-active');
|
|
|
|
}
|
|
|
|
}) : null;
|
|
|
|
// ============================================================
|
|
|
|
|
|
|
|
|
|
|
|
// ====================== mobile search =======================
|
|
|
|
var mobileSearchInputElem = document.querySelector('#search-mobile');
|
|
|
|
var mobileSearchClassElem = document.querySelector('.mobile-search');
|
|
|
|
var mobileSearchBtnElem = document.querySelector('#mobileSearchBtn');
|
|
|
|
var mobileSearchCloseBtnElem = document.querySelector('#search-mobile-close');
|
|
|
|
var mobileSearchContainer = document.querySelector('#search-mobile-container');
|
|
|
|
var mobileSearchResultsElem = document.querySelector('#search-mobile-results');
|
|
|
|
var htmlElem = document.querySelector('html');
|
|
|
|
|
|
|
|
if (mobileSearchClassElem) {
|
|
|
|
mobileSearchClassElem.style.display = 'none';
|
|
|
|
}
|
|
|
|
|
|
|
|
mobileSearchBtnElem ?
|
|
|
|
mobileSearchBtnElem.addEventListener('click', function () {
|
|
|
|
if (mobileSearchContainer) {
|
|
|
|
mobileSearchContainer.style.display = 'block';
|
|
|
|
}
|
|
|
|
|
|
|
|
if (mobileSearchInputElem) {
|
|
|
|
mobileSearchInputElem.focus();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (htmlElem) {
|
|
|
|
htmlElem.style.overflowY = 'hidden';
|
|
|
|
}
|
|
|
|
}) : null;
|
|
|
|
|
|
|
|
mobileSearchCloseBtnElem ?
|
|
|
|
mobileSearchCloseBtnElem.addEventListener('click', function() {
|
|
|
|
if (mobileSearchContainer) {
|
|
|
|
mobileSearchContainer.style.display = 'none';
|
|
|
|
}
|
|
|
|
|
|
|
|
if (mobileSearchInputElem) {
|
|
|
|
mobileSearchInputElem.value = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
if (mobileSearchResultsElem) {
|
|
|
|
while (mobileSearchResultsElem.firstChild) {
|
|
|
|
mobileSearchResultsElem.removeChild(mobileSearchResultsElem.firstChild);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (htmlElem) {
|
|
|
|
htmlElem.style.overflowY = 'visible';
|
|
|
|
}
|
|
|
|
}) : null;
|
|
|
|
|
|
|
|
mobileSearchInputElem ?
|
|
|
|
mobileSearchInputElem.addEventListener('keydown', function(e) {
|
2020-01-23 13:00:38 +00:00
|
|
|
var keyCode = e.which || e.keyCode;
|
|
|
|
if (e.key === 'Escape' || keyCode === 27) {
|
2020-01-06 16:41:38 +00:00
|
|
|
if (mobileSearchContainer) {
|
|
|
|
mobileSearchContainer.style.display = 'none';
|
|
|
|
}
|
|
|
|
|
|
|
|
if (mobileSearchInputElem) {
|
|
|
|
mobileSearchInputElem.value = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
if (mobileSearchResultsElem) {
|
|
|
|
while (mobileSearchResultsElem.firstChild) {
|
|
|
|
mobileSearchResultsElem.removeChild(mobileSearchResultsElem.firstChild);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (htmlElem) {
|
|
|
|
htmlElem.style.overflowY = 'visible';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}) : null;
|
|
|
|
// ============================================================
|
|
|
|
|
|
|
|
|
|
|
|
// ======================= theme change =======================
|
|
|
|
var localTheme = localStorage.getItem('theme');
|
|
|
|
var rootEleme = document.getElementById('root');
|
|
|
|
var selectThemeElem = document.querySelectorAll('.select-theme');
|
|
|
|
var selectThemeItemElem = document.querySelectorAll('.select-theme__item');
|
|
|
|
|
|
|
|
if (localTheme) {
|
|
|
|
selectThemeItemElem ?
|
|
|
|
selectThemeItemElem.forEach(function (elem) {
|
|
|
|
if (elem.text.trim() === localTheme) {
|
|
|
|
elem.classList.add('is-active');
|
|
|
|
} else {
|
|
|
|
elem.classList.remove('is-active');
|
|
|
|
}
|
|
|
|
}) : null;
|
|
|
|
}
|
|
|
|
|
|
|
|
selectThemeItemElem ?
|
|
|
|
selectThemeItemElem.forEach(function (v, i) {
|
|
|
|
v.addEventListener('click', function (e) {
|
|
|
|
var selectedThemeVariant = e.target.text.trim();
|
|
|
|
localStorage.setItem('theme', selectedThemeVariant);
|
|
|
|
|
|
|
|
rootEleme.removeAttribute('class');
|
2020-01-23 13:00:38 +00:00
|
|
|
rootEleme.classList.add('theme__' + selectedThemeVariant);
|
2020-01-06 16:41:38 +00:00
|
|
|
selectThemeElem.forEach(function(rootElem) {
|
|
|
|
rootElem.querySelectorAll('a').forEach(function (elem) {
|
|
|
|
if (elem.classList) {
|
|
|
|
if (elem.text.trim() === selectedThemeVariant) {
|
|
|
|
if (!elem.classList.contains('is-active')) {
|
|
|
|
elem.classList.add('is-active');
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (elem.classList.contains('is-active')) {
|
|
|
|
elem.classList.remove('is-active');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
if (window.mermaid) {
|
|
|
|
if (selectedThemeVariant === "dark" || selectedThemeVariant === "hacker") {
|
|
|
|
mermaid.initialize({ theme: 'dark' });
|
|
|
|
location.reload();
|
|
|
|
} else {
|
|
|
|
mermaid.initialize({ theme: 'default' });
|
|
|
|
location.reload();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var utterances = document.querySelector('iframe');
|
|
|
|
if (utterances) {
|
|
|
|
utterances.contentWindow.postMessage({
|
|
|
|
type: 'set-theme',
|
2020-01-08 17:58:15 +00:00
|
|
|
theme: selectedThemeVariant === "dark" || selectedThemeVariant === "hacker" ? 'photon-dark' : selectedThemeVariant === 'kimbie' ? 'github-dark-orange' : 'github-light',
|
2020-01-06 16:41:38 +00:00
|
|
|
}, 'https://utteranc.es');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}) : null;
|
2020-01-08 17:58:15 +00:00
|
|
|
// ============================================================
|
2020-01-06 16:41:38 +00:00
|
|
|
|
|
|
|
|
|
|
|
// ========================== search ==========================
|
2019-11-27 01:16:53 +00:00
|
|
|
var searchResults = null;
|
|
|
|
var searchMenu = null;
|
2019-12-30 12:38:02 +00:00
|
|
|
var searchText = null;
|
|
|
|
|
|
|
|
{{ $enableSearchHighlight := ($.Param "enableSearchHighlight") }}
|
|
|
|
var enableSearchHighlight = JSON.parse({{ $enableSearchHighlight | jsonify }});
|
|
|
|
|
2019-12-09 14:00:51 +00:00
|
|
|
var fuse = null;
|
2019-11-27 01:16:53 +00:00
|
|
|
|
|
|
|
function endsWith(str, suffix) {
|
|
|
|
return str.indexOf(suffix, str.length - suffix.length) !== -1;
|
|
|
|
}
|
|
|
|
|
2019-12-09 14:00:51 +00:00
|
|
|
function initFuse() {
|
2020-01-06 16:41:38 +00:00
|
|
|
var xhr = new XMLHttpRequest();
|
2020-02-05 17:23:27 +00:00
|
|
|
xhr.open('GET', permalink + "index.json");
|
2020-01-06 16:41:38 +00:00
|
|
|
xhr.setRequestHeader('Content-Type', 'application/json; charset=utf-8');
|
|
|
|
xhr.onload = function () {
|
|
|
|
if (xhr.status === 200) {
|
|
|
|
fuse = new Fuse(JSON.parse(xhr.response.toString('utf-8')), {
|
2019-12-30 12:38:02 +00:00
|
|
|
keys: ['title', 'description', 'content'],
|
|
|
|
includeMatches: enableSearchHighlight,
|
|
|
|
shouldSort: true,
|
2020-01-01 16:35:53 +00:00
|
|
|
threshold: 0.4,
|
2019-12-30 12:38:02 +00:00
|
|
|
location: 0,
|
|
|
|
distance: 100,
|
|
|
|
maxPatternLength: 32,
|
2020-01-26 12:39:28 +00:00
|
|
|
minMatchCharLength: 1,
|
2019-11-27 01:16:53 +00:00
|
|
|
});
|
2020-01-06 16:41:38 +00:00
|
|
|
}
|
|
|
|
else {
|
2020-01-23 13:00:38 +00:00
|
|
|
console.error('[' + xhr.status + ']Error:', xhr.statusText);
|
2020-01-06 16:41:38 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
xhr.send();
|
2019-11-27 01:16:53 +00:00
|
|
|
}
|
|
|
|
|
2019-12-30 12:38:02 +00:00
|
|
|
function renderSearchResults(results) { // [{}, {}, ...] or [{item: {}, matches: []}, ...]
|
2019-11-27 01:16:53 +00:00
|
|
|
searchResults = document.getElementById('search-results');
|
|
|
|
searchMenu = document.getElementById('search-menu');
|
|
|
|
searchResults.setAttribute('class', 'dropdown is-active');
|
2020-02-03 01:59:33 +00:00
|
|
|
|
2019-11-27 01:16:53 +00:00
|
|
|
var content = document.createElement('div');
|
|
|
|
content.setAttribute('class', 'dropdown-content search-content');
|
|
|
|
|
|
|
|
if (results.length > 0) {
|
|
|
|
results.forEach(function (result) {
|
|
|
|
var item = document.createElement('a');
|
|
|
|
item.setAttribute('href', result.uri);
|
|
|
|
item.setAttribute('class', 'dropdown-item');
|
2020-01-23 13:00:38 +00:00
|
|
|
item.innerHTML = '<div class="menu-item"><div class="menu-item__title">📄 ' + result.title + '</div><div class="menu-item__desc">' + (result.description ? result.description : result.content) + '</div></div>';
|
2019-11-27 01:16:53 +00:00
|
|
|
content.appendChild(item);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
var item = document.createElement('span');
|
|
|
|
item.setAttribute('class', 'dropdown-item');
|
|
|
|
item.innerText = 'No results found';
|
|
|
|
content.appendChild(item);
|
|
|
|
}
|
|
|
|
|
|
|
|
while (searchMenu.hasChildNodes()) {
|
|
|
|
searchMenu.removeChild(
|
|
|
|
searchMenu.lastChild
|
|
|
|
);
|
|
|
|
}
|
|
|
|
searchMenu.appendChild(content);
|
|
|
|
}
|
|
|
|
|
2020-02-03 01:59:33 +00:00
|
|
|
function renderSearchHighlightResults(results) {
|
2019-12-30 12:38:02 +00:00
|
|
|
searchResults = document.getElementById('search-results');
|
|
|
|
searchMenu = document.getElementById('search-menu');
|
|
|
|
searchResults.setAttribute('class', 'dropdown is-active');
|
|
|
|
|
|
|
|
var content = document.createElement('div');
|
|
|
|
content.setAttribute('class', 'dropdown-content search-content');
|
|
|
|
|
|
|
|
if (results.length > 0) {
|
|
|
|
results.forEach(function (result) {
|
|
|
|
var item = document.createElement('a');
|
|
|
|
item.setAttribute('href', result.item.uri);
|
|
|
|
item.setAttribute('class', 'dropdown-item');
|
2020-01-23 13:00:38 +00:00
|
|
|
item.innerHTML = '<div class="menu-item"><div class="menu-item__title">📄 ' + generateHighlightedText(result.item.title, result.matches[0].indices) + '</div><div class="menu-item__desc">' + (result.matches[1] ? generateHighlightedText(result.item.description, result.matches[1].indices) : result.matches[2] ? generateHighlightedText(result.item.content, result.matches[2].indices) : '') + '</div></div>';
|
2019-12-30 12:38:02 +00:00
|
|
|
content.appendChild(item);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
var item = document.createElement('span');
|
|
|
|
item.setAttribute('class', 'dropdown-item');
|
|
|
|
item.innerText = 'No results found';
|
|
|
|
content.appendChild(item);
|
|
|
|
}
|
|
|
|
|
|
|
|
while (searchMenu.hasChildNodes()) {
|
|
|
|
searchMenu.removeChild(
|
|
|
|
searchMenu.lastChild
|
|
|
|
);
|
|
|
|
}
|
|
|
|
searchMenu.appendChild(content);
|
|
|
|
}
|
|
|
|
|
2019-11-27 01:16:53 +00:00
|
|
|
function renderSearchResultsMobile(results) {
|
|
|
|
searchResults = document.getElementById('search-mobile-results');
|
|
|
|
|
|
|
|
var content = document.createElement('div');
|
|
|
|
content.setAttribute('class', 'mobile-search__content');
|
|
|
|
|
|
|
|
if (results.length > 0) {
|
|
|
|
results.forEach(function (result) {
|
|
|
|
var item = document.createElement('a');
|
|
|
|
item.setAttribute('href', result.uri);
|
2020-01-23 13:00:38 +00:00
|
|
|
item.innerHTML = '<div class="mobile-search__item"><div class="mobile-search__item--title">📄 ' + result.title + '</div><div class="mobile-search__item--desc">' + (result.description ? result.description : result.content) + '</div></div>';
|
2019-11-27 01:16:53 +00:00
|
|
|
content.appendChild(item);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
var item = document.createElement('span');
|
|
|
|
content.appendChild(item);
|
|
|
|
}
|
|
|
|
|
2020-01-06 16:41:38 +00:00
|
|
|
let wrap = document.getElementById('search-mobile-results');
|
|
|
|
while (wrap.firstChild) {
|
|
|
|
wrap.removeChild(wrap.firstChild)
|
|
|
|
}
|
|
|
|
searchResults.appendChild(content);
|
2019-11-27 01:16:53 +00:00
|
|
|
}
|
|
|
|
|
2019-12-30 12:38:02 +00:00
|
|
|
function renderSearchHighlightResultsMobile(results) {
|
|
|
|
searchResults = document.getElementById('search-mobile-results');
|
|
|
|
|
|
|
|
var content = document.createElement('div');
|
|
|
|
content.setAttribute('class', 'mobile-search__content');
|
|
|
|
|
|
|
|
if (results.length > 0) {
|
|
|
|
results.forEach(function (result) {
|
|
|
|
var item = document.createElement('a');
|
|
|
|
item.setAttribute('href', result.item.uri);
|
2020-01-23 13:00:38 +00:00
|
|
|
item.innerHTML = '<div class="mobile-search__item"><div class="mobile-search__item--title">📄 ' + generateHighlightedText(result.item.title, result.matches[0].indices) + '</div><div class="mobile-search__item--desc">' + (result.matches[1] ? generateHighlightedText(result.item.description, result.matches[1].indices) : result.matches[2] ? generateHighlightedText(result.item.content, result.matches[2].indices) : '') + '</div></div>';
|
2019-12-30 12:38:02 +00:00
|
|
|
content.appendChild(item);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
var item = document.createElement('span');
|
|
|
|
content.appendChild(item);
|
|
|
|
}
|
|
|
|
|
2020-01-06 16:41:38 +00:00
|
|
|
let wrap = document.getElementById('search-mobile-results');
|
|
|
|
while (wrap.firstChild) {
|
|
|
|
wrap.removeChild(wrap.firstChild)
|
|
|
|
}
|
2019-12-30 12:38:02 +00:00
|
|
|
searchResults.appendChild(content);
|
|
|
|
}
|
|
|
|
|
|
|
|
function generateHighlightedText(text, regions) {
|
2020-01-10 06:13:21 +00:00
|
|
|
if (!regions) {
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
|
2019-12-30 12:38:02 +00:00
|
|
|
var content = '', nextUnhighlightedRegionStartingIndex = 0;
|
|
|
|
|
|
|
|
regions.forEach(function(region) {
|
2020-01-10 06:13:21 +00:00
|
|
|
if (region[0] === region[1]) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2019-12-30 12:38:02 +00:00
|
|
|
content += '' +
|
|
|
|
text.substring(nextUnhighlightedRegionStartingIndex, region[0]) +
|
|
|
|
'<span class="search__highlight">' +
|
|
|
|
text.substring(region[0], region[1] + 1) +
|
|
|
|
'</span>' +
|
|
|
|
'';
|
|
|
|
nextUnhighlightedRegionStartingIndex = region[1] + 1;
|
|
|
|
});
|
|
|
|
|
|
|
|
content += text.substring(nextUnhighlightedRegionStartingIndex);
|
|
|
|
|
|
|
|
return content;
|
|
|
|
};
|
|
|
|
|
2019-12-09 14:00:51 +00:00
|
|
|
initFuse();
|
2019-11-27 01:16:53 +00:00
|
|
|
|
2020-01-06 16:41:38 +00:00
|
|
|
var searchElem = document.getElementById('search');
|
|
|
|
var searchMobile = document.getElementById('search-mobile');
|
|
|
|
|
2020-01-23 13:00:38 +00:00
|
|
|
searchElem ?
|
2020-01-06 16:41:38 +00:00
|
|
|
searchElem.addEventListener('input', function(e) {
|
2019-11-27 01:16:53 +00:00
|
|
|
if (!e.target.value) {
|
2020-01-06 16:41:38 +00:00
|
|
|
document.getElementById('search-results').setAttribute('class', 'dropdown');
|
2019-11-27 01:16:53 +00:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2020-01-06 16:41:38 +00:00
|
|
|
if (window.innerWidth < 770) {
|
2019-11-27 01:16:53 +00:00
|
|
|
return null;
|
2020-01-06 16:41:38 +00:00
|
|
|
}
|
2019-11-27 01:16:53 +00:00
|
|
|
|
2019-12-30 12:38:02 +00:00
|
|
|
searchText = e.target.value;
|
2019-12-09 14:00:51 +00:00
|
|
|
var results = fuse.search(e.target.value);
|
2019-12-30 12:38:02 +00:00
|
|
|
if (enableSearchHighlight) {
|
|
|
|
renderSearchHighlightResults(results);
|
|
|
|
} else {
|
|
|
|
renderSearchResults(results);
|
|
|
|
}
|
2020-01-23 13:00:38 +00:00
|
|
|
}) : null;
|
2019-11-27 01:16:53 +00:00
|
|
|
|
2020-01-23 13:00:38 +00:00
|
|
|
searchElem ?
|
2020-01-06 16:41:38 +00:00
|
|
|
searchElem.addEventListener('blur', function() {
|
|
|
|
if (window.innerWidth < 770) {
|
2019-11-27 01:16:53 +00:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
setTimeout(function () {
|
2020-01-06 16:41:38 +00:00
|
|
|
document.getElementById('search-results').setAttribute('class', 'dropdown');
|
2019-11-27 01:16:53 +00:00
|
|
|
}, 100);
|
2020-01-23 13:00:38 +00:00
|
|
|
}) : null;
|
2019-11-27 01:16:53 +00:00
|
|
|
|
2020-01-23 13:00:38 +00:00
|
|
|
searchElem ?
|
2020-01-06 16:41:38 +00:00
|
|
|
searchElem.addEventListener('click', function(e) {
|
|
|
|
if (window.innerWidth < 770) {
|
2019-11-27 01:16:53 +00:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
if (!e.target.value) {
|
2020-01-06 16:41:38 +00:00
|
|
|
document.getElementById('search-results').setAttribute('class', 'dropdown');
|
2019-11-27 01:16:53 +00:00
|
|
|
return null;
|
|
|
|
}
|
2020-01-06 16:41:38 +00:00
|
|
|
|
2019-12-30 12:38:02 +00:00
|
|
|
searchText = e.target.value;
|
2019-12-09 14:00:51 +00:00
|
|
|
var results = fuse.search(e.target.value);
|
2019-12-30 12:38:02 +00:00
|
|
|
if (enableSearchHighlight) {
|
|
|
|
renderSearchHighlightResults(results);
|
|
|
|
} else {
|
|
|
|
renderSearchResults(results);
|
|
|
|
}
|
2020-01-23 13:00:38 +00:00
|
|
|
}) : null;
|
2020-01-06 16:41:38 +00:00
|
|
|
|
|
|
|
function indexInParent(node) {
|
|
|
|
var children = node.parentNode.childNodes;
|
|
|
|
var num = 0;
|
|
|
|
for (var i = 0; i < children.length; i++) {
|
|
|
|
if (children[i] == node) return num;
|
|
|
|
if (children[i].nodeType == 1) num++;
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
2019-11-27 01:16:53 +00:00
|
|
|
|
2020-01-06 16:41:38 +00:00
|
|
|
var searchMenuElem = document.getElementById("search-menu");
|
|
|
|
var activeItem = document.querySelector('#search-menu .dropdown-item.is-active');
|
|
|
|
var activeIndex = null;
|
|
|
|
var items = null;
|
|
|
|
var searchContainerMaxHeight = 350;
|
|
|
|
|
2020-01-23 13:00:38 +00:00
|
|
|
searchElem ?
|
2020-01-06 16:41:38 +00:00
|
|
|
searchElem.addEventListener('keydown', function(e) {
|
|
|
|
if (window.innerWidth < 770) {
|
2019-11-27 01:16:53 +00:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2020-01-06 16:41:38 +00:00
|
|
|
var items = document.querySelectorAll('#search-menu .dropdown-item');
|
2020-01-23 13:00:38 +00:00
|
|
|
var keyCode = e.which || e.keyCode;
|
2020-01-06 16:41:38 +00:00
|
|
|
|
2020-01-23 13:00:38 +00:00
|
|
|
if (e.key === 'ArrowDown' || keyCode === 40) {
|
2020-01-06 16:41:38 +00:00
|
|
|
if (activeIndex === null) {
|
|
|
|
activeIndex = 0;
|
|
|
|
items[activeIndex].classList.remove('is-active');
|
|
|
|
} else {
|
|
|
|
items[activeIndex].classList.remove('is-active');
|
|
|
|
activeIndex = activeIndex === items.length - 1 ? 0 : activeIndex + 1;
|
|
|
|
}
|
|
|
|
items[activeIndex].classList.add('is-active');
|
|
|
|
|
|
|
|
let overflowedPixel = items[activeIndex].offsetTop + items[activeIndex].clientHeight - searchContainerMaxHeight;
|
|
|
|
if (overflowedPixel > 0) {
|
2020-01-07 07:30:51 +00:00
|
|
|
document.querySelector(".search-content").scrollTop += items[activeIndex].getBoundingClientRect().height;
|
2020-01-06 16:41:38 +00:00
|
|
|
} else if (activeIndex === 0) {
|
|
|
|
document.querySelector(".search-content").scrollTop = 0;
|
|
|
|
}
|
2020-01-23 13:00:38 +00:00
|
|
|
} else if (e.key === 'ArrowUp' || keyCode === 38) {
|
2020-01-06 16:41:38 +00:00
|
|
|
if (activeIndex === null) {
|
|
|
|
activeIndex = items.length - 1;
|
|
|
|
items[activeIndex].classList.remove('is-active');
|
|
|
|
} else {
|
|
|
|
items[activeIndex].classList.remove('is-active');
|
|
|
|
activeIndex = activeIndex === 0 ? items.length - 1 : activeIndex - 1;
|
|
|
|
}
|
|
|
|
items[activeIndex].classList.add('is-active');
|
|
|
|
|
|
|
|
let overflowedPixel = items[activeIndex].offsetTop + items[activeIndex].clientHeight - searchContainerMaxHeight;
|
2020-01-07 07:30:51 +00:00
|
|
|
if (overflowedPixel < 0) {
|
|
|
|
document.querySelector(".search-content").scrollTop -= items[activeIndex].getBoundingClientRect().height;
|
|
|
|
} else {
|
|
|
|
document.querySelector(".search-content").scrollTop = overflowedPixel + items[activeIndex].getBoundingClientRect().height;
|
|
|
|
}
|
2020-01-23 13:00:38 +00:00
|
|
|
} else if (e.key === 'Enter' || keyCode === 13) {
|
2020-02-03 01:59:33 +00:00
|
|
|
if (items[activeIndex] && items[activeIndex].getAttribute('href')) {
|
|
|
|
location.href = items[activeIndex].getAttribute('href');
|
2019-11-27 01:16:53 +00:00
|
|
|
}
|
2020-01-23 13:00:38 +00:00
|
|
|
} else if (e.key === 'Escape' || keyCode === 27) {
|
2020-01-07 07:30:51 +00:00
|
|
|
e.target.value = null;
|
|
|
|
if (searchResults) {
|
|
|
|
searchResults.classList.remove('is-active');
|
|
|
|
}
|
2019-11-27 01:16:53 +00:00
|
|
|
}
|
2020-01-23 13:00:38 +00:00
|
|
|
}) : null;
|
2019-11-27 01:16:53 +00:00
|
|
|
|
2020-01-23 13:00:38 +00:00
|
|
|
searchMobile ?
|
2020-01-06 16:41:38 +00:00
|
|
|
searchMobile.addEventListener('input', function(e) {
|
2019-11-27 01:16:53 +00:00
|
|
|
if (!e.target.value) {
|
2020-01-06 16:41:38 +00:00
|
|
|
let wrap = document.getElementById('search-mobile-results');
|
|
|
|
while (wrap.firstChild) {
|
|
|
|
wrap.removeChild(wrap.firstChild);
|
|
|
|
}
|
2019-11-27 01:16:53 +00:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2019-12-30 12:38:02 +00:00
|
|
|
searchText = e.target.value;
|
2019-12-09 14:00:51 +00:00
|
|
|
var results = fuse.search(e.target.value);
|
2019-11-27 01:16:53 +00:00
|
|
|
renderSearchResultsMobile(results);
|
2019-12-30 12:38:02 +00:00
|
|
|
if (enableSearchHighlight) {
|
|
|
|
renderSearchHighlightResultsMobile(results);
|
|
|
|
} else {
|
|
|
|
renderSearchResultsMobile(results);
|
|
|
|
}
|
2020-01-23 13:00:38 +00:00
|
|
|
}) : null;
|
2020-01-06 16:41:38 +00:00
|
|
|
// ============================================================
|
|
|
|
});
|
2019-11-27 01:16:53 +00:00
|
|
|
</script>
|