Hugo template rip commit. When in doubut steal it out
This commit is contained in:
parent
d709e5fcc5
commit
050160c326
BIN
service/static/bg.png
(Stored with Git LFS)
Normal file
BIN
service/static/bg.png
(Stored with Git LFS)
Normal file
Binary file not shown.
3
service/static/favicon.png
Normal file
3
service/static/favicon.png
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:4582377054b2a53e18c5f212a7f28aaf6915a6765d8f2f2b77b041152e8068ef
|
||||||
|
size 19080
|
2
service/static/js/breakpoints.min.js
vendored
Normal file
2
service/static/js/breakpoints.min.js
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
/* breakpoints.js v1.0 | @ajlkn | MIT licensed */
|
||||||
|
var breakpoints=function(){"use strict";function e(e){t.init(e)}var t={list:null,media:{},events:[],init:function(e){t.list=e,window.addEventListener("resize",t.poll),window.addEventListener("orientationchange",t.poll),window.addEventListener("load",t.poll),window.addEventListener("fullscreenchange",t.poll)},active:function(e){var n,a,s,i,r,d,c;if(!(e in t.media)){if(">="==e.substr(0,2)?(a="gte",n=e.substr(2)):"<="==e.substr(0,2)?(a="lte",n=e.substr(2)):">"==e.substr(0,1)?(a="gt",n=e.substr(1)):"<"==e.substr(0,1)?(a="lt",n=e.substr(1)):"!"==e.substr(0,1)?(a="not",n=e.substr(1)):(a="eq",n=e),n&&n in t.list)if(i=t.list[n],Array.isArray(i)){if(r=parseInt(i[0]),d=parseInt(i[1]),isNaN(r)){if(isNaN(d))return;c=i[1].substr(String(d).length)}else c=i[0].substr(String(r).length);if(isNaN(r))switch(a){case"gte":s="screen";break;case"lte":s="screen and (max-width: "+d+c+")";break;case"gt":s="screen and (min-width: "+(d+1)+c+")";break;case"lt":s="screen and (max-width: -1px)";break;case"not":s="screen and (min-width: "+(d+1)+c+")";break;default:s="screen and (max-width: "+d+c+")"}else if(isNaN(d))switch(a){case"gte":s="screen and (min-width: "+r+c+")";break;case"lte":s="screen";break;case"gt":s="screen and (max-width: -1px)";break;case"lt":s="screen and (max-width: "+(r-1)+c+")";break;case"not":s="screen and (max-width: "+(r-1)+c+")";break;default:s="screen and (min-width: "+r+c+")"}else switch(a){case"gte":s="screen and (min-width: "+r+c+")";break;case"lte":s="screen and (max-width: "+d+c+")";break;case"gt":s="screen and (min-width: "+(d+1)+c+")";break;case"lt":s="screen and (max-width: "+(r-1)+c+")";break;case"not":s="screen and (max-width: "+(r-1)+c+"), screen and (min-width: "+(d+1)+c+")";break;default:s="screen and (min-width: "+r+c+") and (max-width: "+d+c+")"}}else s="("==i.charAt(0)?"screen and "+i:i;t.media[e]=!!s&&s}return t.media[e]!==!1&&window.matchMedia(t.media[e]).matches},on:function(e,n){t.events.push({query:e,handler:n,state:!1}),t.active(e)&&n()},poll:function(){var e,n;for(e=0;e<t.events.length;e++)n=t.events[e],t.active(n.query)?n.state||(n.state=!0,n.handler()):n.state&&(n.state=!1)}};return e._=t,e.on=function(e,n){t.on(e,n)},e.active=function(e){return t.active(e)},e}();!function(e,t){"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?module.exports=t():e.breakpoints=t()}(this,function(){return breakpoints});
|
2
service/static/js/browser.min.js
vendored
Normal file
2
service/static/js/browser.min.js
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
/* browser.js v1.0 | @ajlkn | MIT licensed */
|
||||||
|
var browser=function(){"use strict";var e={name:null,version:null,os:null,osVersion:null,touch:null,mobile:null,_canUse:null,canUse:function(n){e._canUse||(e._canUse=document.createElement("div"));var o=e._canUse.style,r=n.charAt(0).toUpperCase()+n.slice(1);return n in o||"Moz"+r in o||"Webkit"+r in o||"O"+r in o||"ms"+r in o},init:function(){var n,o,r,i,t=navigator.userAgent;for(n="other",o=0,r=[["firefox",/Firefox\/([0-9\.]+)/],["bb",/BlackBerry.+Version\/([0-9\.]+)/],["bb",/BB[0-9]+.+Version\/([0-9\.]+)/],["opera",/OPR\/([0-9\.]+)/],["opera",/Opera\/([0-9\.]+)/],["edge",/Edge\/([0-9\.]+)/],["safari",/Version\/([0-9\.]+).+Safari/],["chrome",/Chrome\/([0-9\.]+)/],["ie",/MSIE ([0-9]+)/],["ie",/Trident\/.+rv:([0-9]+)/]],i=0;i<r.length;i++)if(t.match(r[i][1])){n=r[i][0],o=parseFloat(RegExp.$1);break}for(e.name=n,e.version=o,n="other",o=0,r=[["ios",/([0-9_]+) like Mac OS X/,function(e){return e.replace("_",".").replace("_","")}],["ios",/CPU like Mac OS X/,function(e){return 0}],["wp",/Windows Phone ([0-9\.]+)/,null],["android",/Android ([0-9\.]+)/,null],["mac",/Macintosh.+Mac OS X ([0-9_]+)/,function(e){return e.replace("_",".").replace("_","")}],["windows",/Windows NT ([0-9\.]+)/,null],["bb",/BlackBerry.+Version\/([0-9\.]+)/,null],["bb",/BB[0-9]+.+Version\/([0-9\.]+)/,null],["linux",/Linux/,null],["bsd",/BSD/,null],["unix",/X11/,null]],i=0;i<r.length;i++)if(t.match(r[i][1])){n=r[i][0],o=parseFloat(r[i][2]?r[i][2](RegExp.$1):RegExp.$1);break}e.os=n,e.osVersion=o,e.touch="wp"==e.os?navigator.msMaxTouchPoints>0:!!("ontouchstart"in window),e.mobile="wp"==e.os||"android"==e.os||"ios"==e.os||"bb"==e.os}};return e.init(),e}();!function(e,n){"function"==typeof define&&define.amd?define([],n):"object"==typeof exports?module.exports=n():e.browser=n()}(this,function(){return browser});
|
2
service/static/js/jquery.min.js
vendored
Normal file
2
service/static/js/jquery.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
417
service/static/js/main.js
Normal file
417
service/static/js/main.js
Normal file
@ -0,0 +1,417 @@
|
|||||||
|
/*
|
||||||
|
Dimension by HTML5 UP
|
||||||
|
html5up.net | @ajlkn
|
||||||
|
Free for personal and commercial use under the CCA 3.0 license (html5up.net/license)
|
||||||
|
*/
|
||||||
|
|
||||||
|
(function($) {
|
||||||
|
|
||||||
|
var $window = $(window),
|
||||||
|
$body = $('body'),
|
||||||
|
$wrapper = $('#wrapper'),
|
||||||
|
$header = $('#header'),
|
||||||
|
$footer = $('#footer'),
|
||||||
|
$main = $('#main'),
|
||||||
|
$main_articles = $main.children('article');
|
||||||
|
|
||||||
|
// Breakpoints.
|
||||||
|
breakpoints({
|
||||||
|
xlarge: [ '1281px', '1680px' ],
|
||||||
|
large: [ '981px', '1280px' ],
|
||||||
|
medium: [ '737px', '980px' ],
|
||||||
|
small: [ '481px', '736px' ],
|
||||||
|
xsmall: [ '361px', '480px' ],
|
||||||
|
xxsmall: [ null, '360px' ]
|
||||||
|
});
|
||||||
|
|
||||||
|
// Play initial animations on page load.
|
||||||
|
$window.on('load', function() {
|
||||||
|
window.setTimeout(function() {
|
||||||
|
$body.removeClass('is-preload');
|
||||||
|
}, 100);
|
||||||
|
});
|
||||||
|
|
||||||
|
// Fix: Flexbox min-height bug on IE.
|
||||||
|
if (browser.name == 'ie') {
|
||||||
|
|
||||||
|
var flexboxFixTimeoutId;
|
||||||
|
|
||||||
|
$window.on('resize.flexbox-fix', function() {
|
||||||
|
|
||||||
|
clearTimeout(flexboxFixTimeoutId);
|
||||||
|
|
||||||
|
flexboxFixTimeoutId = setTimeout(function() {
|
||||||
|
|
||||||
|
if ($wrapper.prop('scrollHeight') > $window.height())
|
||||||
|
$wrapper.css('height', 'auto');
|
||||||
|
else
|
||||||
|
$wrapper.css('height', '100vh');
|
||||||
|
|
||||||
|
}, 250);
|
||||||
|
|
||||||
|
}).triggerHandler('resize.flexbox-fix');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Nav.
|
||||||
|
var $nav = $header.children('nav'),
|
||||||
|
$nav_li = $nav.find('li');
|
||||||
|
|
||||||
|
// Add "middle" alignment classes if we're dealing with an even number of items.
|
||||||
|
if ($nav_li.length % 2 == 0) {
|
||||||
|
|
||||||
|
$nav.addClass('use-middle');
|
||||||
|
$nav_li.eq( ($nav_li.length / 2) ).addClass('is-middle');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Main.
|
||||||
|
var delay = 325,
|
||||||
|
locked = false,
|
||||||
|
nohash = false;
|
||||||
|
|
||||||
|
// Set nohash.
|
||||||
|
if (location.hash == '' || location.hash == '#')
|
||||||
|
nohash = true;
|
||||||
|
|
||||||
|
// Methods.
|
||||||
|
$main._show = function(id, initial) {
|
||||||
|
|
||||||
|
var $article = $main_articles.filter('#' + id);
|
||||||
|
|
||||||
|
// No such article? Bail.
|
||||||
|
if ($article.length == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Handle lock.
|
||||||
|
|
||||||
|
// Already locked? Speed through "show" steps w/o delays.
|
||||||
|
if (locked || (typeof initial != 'undefined' && initial === true)) {
|
||||||
|
|
||||||
|
// Mark as switching.
|
||||||
|
$body.addClass('is-switching');
|
||||||
|
|
||||||
|
// Mark as visible.
|
||||||
|
$body.addClass('is-article-visible');
|
||||||
|
|
||||||
|
// Deactivate all articles (just in case one's already active).
|
||||||
|
$main_articles.removeClass('active');
|
||||||
|
|
||||||
|
// Hide header, footer.
|
||||||
|
$header.hide();
|
||||||
|
$footer.hide();
|
||||||
|
|
||||||
|
// Show main, article.
|
||||||
|
$main.show();
|
||||||
|
$article.show();
|
||||||
|
|
||||||
|
// Activate article.
|
||||||
|
$article.addClass('active');
|
||||||
|
|
||||||
|
// Unlock.
|
||||||
|
locked = false;
|
||||||
|
|
||||||
|
// Unmark as switching.
|
||||||
|
setTimeout(function() {
|
||||||
|
$body.removeClass('is-switching');
|
||||||
|
}, (initial ? 1000 : 0));
|
||||||
|
|
||||||
|
return;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Lock.
|
||||||
|
locked = true;
|
||||||
|
|
||||||
|
// Article already visible? Just swap articles.
|
||||||
|
if ($body.hasClass('is-article-visible')) {
|
||||||
|
|
||||||
|
// Deactivate current article.
|
||||||
|
var $currentArticle = $main_articles.filter('.active');
|
||||||
|
|
||||||
|
$currentArticle.removeClass('active');
|
||||||
|
|
||||||
|
// Show article.
|
||||||
|
setTimeout(function() {
|
||||||
|
|
||||||
|
// Hide current article.
|
||||||
|
$currentArticle.hide();
|
||||||
|
|
||||||
|
// Show article.
|
||||||
|
$article.show();
|
||||||
|
|
||||||
|
// Activate article.
|
||||||
|
setTimeout(function() {
|
||||||
|
|
||||||
|
$article.addClass('active');
|
||||||
|
|
||||||
|
// Window stuff.
|
||||||
|
$window
|
||||||
|
.scrollTop(0)
|
||||||
|
.triggerHandler('resize.flexbox-fix');
|
||||||
|
|
||||||
|
// Unlock.
|
||||||
|
setTimeout(function() {
|
||||||
|
locked = false;
|
||||||
|
}, delay);
|
||||||
|
|
||||||
|
}, 25);
|
||||||
|
|
||||||
|
}, delay);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Otherwise, handle as normal.
|
||||||
|
else {
|
||||||
|
|
||||||
|
// Mark as visible.
|
||||||
|
$body
|
||||||
|
.addClass('is-article-visible');
|
||||||
|
|
||||||
|
// Show article.
|
||||||
|
setTimeout(function() {
|
||||||
|
|
||||||
|
// Hide header, footer.
|
||||||
|
$header.hide();
|
||||||
|
$footer.hide();
|
||||||
|
|
||||||
|
// Show main, article.
|
||||||
|
$main.show();
|
||||||
|
$article.show();
|
||||||
|
|
||||||
|
// Activate article.
|
||||||
|
setTimeout(function() {
|
||||||
|
|
||||||
|
$article.addClass('active');
|
||||||
|
|
||||||
|
// Window stuff.
|
||||||
|
$window
|
||||||
|
.scrollTop(0)
|
||||||
|
.triggerHandler('resize.flexbox-fix');
|
||||||
|
|
||||||
|
// Unlock.
|
||||||
|
setTimeout(function() {
|
||||||
|
locked = false;
|
||||||
|
}, delay);
|
||||||
|
|
||||||
|
}, 25);
|
||||||
|
|
||||||
|
}, delay);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
$main._hide = function(addState) {
|
||||||
|
|
||||||
|
var $article = $main_articles.filter('.active');
|
||||||
|
|
||||||
|
// Article not visible? Bail.
|
||||||
|
if (!$body.hasClass('is-article-visible'))
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Add state?
|
||||||
|
if (typeof addState != 'undefined'
|
||||||
|
&& addState === true)
|
||||||
|
history.replaceState(null, null, '/');
|
||||||
|
|
||||||
|
// Handle lock.
|
||||||
|
|
||||||
|
// Already locked? Speed through "hide" steps w/o delays.
|
||||||
|
if (locked) {
|
||||||
|
|
||||||
|
// Mark as switching.
|
||||||
|
$body.addClass('is-switching');
|
||||||
|
|
||||||
|
// Deactivate article.
|
||||||
|
$article.removeClass('active');
|
||||||
|
|
||||||
|
// Hide article, main.
|
||||||
|
$article.hide();
|
||||||
|
$main.hide();
|
||||||
|
|
||||||
|
// Show footer, header.
|
||||||
|
$footer.show();
|
||||||
|
$header.show();
|
||||||
|
|
||||||
|
// Unmark as visible.
|
||||||
|
$body.removeClass('is-article-visible');
|
||||||
|
|
||||||
|
// Unlock.
|
||||||
|
locked = false;
|
||||||
|
|
||||||
|
// Unmark as switching.
|
||||||
|
$body.removeClass('is-switching');
|
||||||
|
|
||||||
|
// Window stuff.
|
||||||
|
$window
|
||||||
|
.scrollTop(0)
|
||||||
|
.triggerHandler('resize.flexbox-fix');
|
||||||
|
|
||||||
|
return;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Lock.
|
||||||
|
locked = true;
|
||||||
|
|
||||||
|
// Deactivate article.
|
||||||
|
$article.removeClass('active');
|
||||||
|
|
||||||
|
// Hide article.
|
||||||
|
setTimeout(function() {
|
||||||
|
|
||||||
|
// Hide article, main.
|
||||||
|
$article.hide();
|
||||||
|
$main.hide();
|
||||||
|
|
||||||
|
// Show footer, header.
|
||||||
|
$footer.show();
|
||||||
|
$header.show();
|
||||||
|
|
||||||
|
// Unmark as visible.
|
||||||
|
setTimeout(function() {
|
||||||
|
|
||||||
|
$body.removeClass('is-article-visible');
|
||||||
|
|
||||||
|
// Window stuff.
|
||||||
|
$window
|
||||||
|
.scrollTop(0)
|
||||||
|
.triggerHandler('resize.flexbox-fix');
|
||||||
|
|
||||||
|
// Unlock.
|
||||||
|
setTimeout(function() {
|
||||||
|
locked = false;
|
||||||
|
}, delay);
|
||||||
|
|
||||||
|
}, 25);
|
||||||
|
|
||||||
|
}, delay);
|
||||||
|
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
// Articles.
|
||||||
|
$main_articles.each(function() {
|
||||||
|
|
||||||
|
var $this = $(this);
|
||||||
|
|
||||||
|
// Close.
|
||||||
|
$('<div class="close">Close</div>')
|
||||||
|
.appendTo($this)
|
||||||
|
.on('click', function() {
|
||||||
|
if (nohash) {
|
||||||
|
history.go(-1);
|
||||||
|
} else {
|
||||||
|
$main._hide(true);
|
||||||
|
nohash = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Prevent clicks from inside article from bubbling.
|
||||||
|
$this.on('click', function(event) {
|
||||||
|
event.stopPropagation();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
// Events.
|
||||||
|
$body.on('click', function(event) {
|
||||||
|
|
||||||
|
// Article visible? Go back. Hide when article is accessed first.
|
||||||
|
if ($body.hasClass('is-article-visible')) {
|
||||||
|
if (nohash) {
|
||||||
|
history.go(-1);
|
||||||
|
} else {
|
||||||
|
$main._hide(true);
|
||||||
|
nohash = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
$window.on('keyup', function(event) {
|
||||||
|
|
||||||
|
switch (event.keyCode) {
|
||||||
|
|
||||||
|
case 27:
|
||||||
|
|
||||||
|
// Article visible? Hide.
|
||||||
|
if ($body.hasClass('is-article-visible'))
|
||||||
|
$main._hide(true);
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
$window.on('hashchange', function(event) {
|
||||||
|
|
||||||
|
// Empty hash?
|
||||||
|
if (location.hash == ''
|
||||||
|
|| location.hash == '#') {
|
||||||
|
|
||||||
|
// Prevent default.
|
||||||
|
event.preventDefault();
|
||||||
|
event.stopPropagation();
|
||||||
|
|
||||||
|
// Hide.
|
||||||
|
$main._hide();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Otherwise, check for a matching article.
|
||||||
|
else if ($main_articles.filter(location.hash).length > 0) {
|
||||||
|
|
||||||
|
// Prevent default.
|
||||||
|
event.preventDefault();
|
||||||
|
event.stopPropagation();
|
||||||
|
|
||||||
|
// Show article.
|
||||||
|
$main._show(location.hash.substr(1));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
// Scroll restoration.
|
||||||
|
// This prevents the page from scrolling back to the top on a hashchange.
|
||||||
|
if ('scrollRestoration' in history)
|
||||||
|
history.scrollRestoration = 'manual';
|
||||||
|
else {
|
||||||
|
|
||||||
|
var oldScrollPos = 0,
|
||||||
|
scrollPos = 0,
|
||||||
|
$htmlbody = $('html,body');
|
||||||
|
|
||||||
|
$window
|
||||||
|
.on('scroll', function() {
|
||||||
|
|
||||||
|
oldScrollPos = scrollPos;
|
||||||
|
scrollPos = $htmlbody.scrollTop();
|
||||||
|
|
||||||
|
})
|
||||||
|
.on('hashchange', function() {
|
||||||
|
$window.scrollTop(oldScrollPos);
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Initialize.
|
||||||
|
|
||||||
|
// Hide main, articles.
|
||||||
|
$main.hide();
|
||||||
|
$main_articles.hide();
|
||||||
|
|
||||||
|
// Initial article.
|
||||||
|
if (location.hash != ''
|
||||||
|
&& location.hash != '#')
|
||||||
|
$window.on('load', function() {
|
||||||
|
$main._show(location.hash.substr(1), true);
|
||||||
|
});
|
||||||
|
|
||||||
|
})(jQuery);
|
587
service/static/js/util.js
Normal file
587
service/static/js/util.js
Normal file
@ -0,0 +1,587 @@
|
|||||||
|
(function($) {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generate an indented list of links from a nav. Meant for use with panel().
|
||||||
|
* @return {jQuery} jQuery object.
|
||||||
|
*/
|
||||||
|
$.fn.navList = function() {
|
||||||
|
|
||||||
|
var $this = $(this);
|
||||||
|
$a = $this.find('a'),
|
||||||
|
b = [];
|
||||||
|
|
||||||
|
$a.each(function() {
|
||||||
|
|
||||||
|
var $this = $(this),
|
||||||
|
indent = Math.max(0, $this.parents('li').length - 1),
|
||||||
|
href = $this.attr('href'),
|
||||||
|
target = $this.attr('target');
|
||||||
|
|
||||||
|
b.push(
|
||||||
|
'<a ' +
|
||||||
|
'class="link depth-' + indent + '"' +
|
||||||
|
( (typeof target !== 'undefined' && target != '') ? ' target="' + target + '"' : '') +
|
||||||
|
( (typeof href !== 'undefined' && href != '') ? ' href="' + href + '"' : '') +
|
||||||
|
'>' +
|
||||||
|
'<span class="indent-' + indent + '"></span>' +
|
||||||
|
$this.text() +
|
||||||
|
'</a>'
|
||||||
|
);
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
return b.join('');
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Panel-ify an element.
|
||||||
|
* @param {object} userConfig User config.
|
||||||
|
* @return {jQuery} jQuery object.
|
||||||
|
*/
|
||||||
|
$.fn.panel = function(userConfig) {
|
||||||
|
|
||||||
|
// No elements?
|
||||||
|
if (this.length == 0)
|
||||||
|
return $this;
|
||||||
|
|
||||||
|
// Multiple elements?
|
||||||
|
if (this.length > 1) {
|
||||||
|
|
||||||
|
for (var i=0; i < this.length; i++)
|
||||||
|
$(this[i]).panel(userConfig);
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Vars.
|
||||||
|
var $this = $(this),
|
||||||
|
$body = $('body'),
|
||||||
|
$window = $(window),
|
||||||
|
id = $this.attr('id'),
|
||||||
|
config;
|
||||||
|
|
||||||
|
// Config.
|
||||||
|
config = $.extend({
|
||||||
|
|
||||||
|
// Delay.
|
||||||
|
delay: 0,
|
||||||
|
|
||||||
|
// Hide panel on link click.
|
||||||
|
hideOnClick: false,
|
||||||
|
|
||||||
|
// Hide panel on escape keypress.
|
||||||
|
hideOnEscape: false,
|
||||||
|
|
||||||
|
// Hide panel on swipe.
|
||||||
|
hideOnSwipe: false,
|
||||||
|
|
||||||
|
// Reset scroll position on hide.
|
||||||
|
resetScroll: false,
|
||||||
|
|
||||||
|
// Reset forms on hide.
|
||||||
|
resetForms: false,
|
||||||
|
|
||||||
|
// Side of viewport the panel will appear.
|
||||||
|
side: null,
|
||||||
|
|
||||||
|
// Target element for "class".
|
||||||
|
target: $this,
|
||||||
|
|
||||||
|
// Class to toggle.
|
||||||
|
visibleClass: 'visible'
|
||||||
|
|
||||||
|
}, userConfig);
|
||||||
|
|
||||||
|
// Expand "target" if it's not a jQuery object already.
|
||||||
|
if (typeof config.target != 'jQuery')
|
||||||
|
config.target = $(config.target);
|
||||||
|
|
||||||
|
// Panel.
|
||||||
|
|
||||||
|
// Methods.
|
||||||
|
$this._hide = function(event) {
|
||||||
|
|
||||||
|
// Already hidden? Bail.
|
||||||
|
if (!config.target.hasClass(config.visibleClass))
|
||||||
|
return;
|
||||||
|
|
||||||
|
// If an event was provided, cancel it.
|
||||||
|
if (event) {
|
||||||
|
|
||||||
|
event.preventDefault();
|
||||||
|
event.stopPropagation();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hide.
|
||||||
|
config.target.removeClass(config.visibleClass);
|
||||||
|
|
||||||
|
// Post-hide stuff.
|
||||||
|
window.setTimeout(function() {
|
||||||
|
|
||||||
|
// Reset scroll position.
|
||||||
|
if (config.resetScroll)
|
||||||
|
$this.scrollTop(0);
|
||||||
|
|
||||||
|
// Reset forms.
|
||||||
|
if (config.resetForms)
|
||||||
|
$this.find('form').each(function() {
|
||||||
|
this.reset();
|
||||||
|
});
|
||||||
|
|
||||||
|
}, config.delay);
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
// Vendor fixes.
|
||||||
|
$this
|
||||||
|
.css('-ms-overflow-style', '-ms-autohiding-scrollbar')
|
||||||
|
.css('-webkit-overflow-scrolling', 'touch');
|
||||||
|
|
||||||
|
// Hide on click.
|
||||||
|
if (config.hideOnClick) {
|
||||||
|
|
||||||
|
$this.find('a')
|
||||||
|
.css('-webkit-tap-highlight-color', 'rgba(0,0,0,0)');
|
||||||
|
|
||||||
|
$this
|
||||||
|
.on('click', 'a', function(event) {
|
||||||
|
|
||||||
|
var $a = $(this),
|
||||||
|
href = $a.attr('href'),
|
||||||
|
target = $a.attr('target');
|
||||||
|
|
||||||
|
if (!href || href == '#' || href == '' || href == '#' + id)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Cancel original event.
|
||||||
|
event.preventDefault();
|
||||||
|
event.stopPropagation();
|
||||||
|
|
||||||
|
// Hide panel.
|
||||||
|
$this._hide();
|
||||||
|
|
||||||
|
// Redirect to href.
|
||||||
|
window.setTimeout(function() {
|
||||||
|
|
||||||
|
if (target == '_blank')
|
||||||
|
window.open(href);
|
||||||
|
else
|
||||||
|
window.location.href = href;
|
||||||
|
|
||||||
|
}, config.delay + 10);
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Event: Touch stuff.
|
||||||
|
$this.on('touchstart', function(event) {
|
||||||
|
|
||||||
|
$this.touchPosX = event.originalEvent.touches[0].pageX;
|
||||||
|
$this.touchPosY = event.originalEvent.touches[0].pageY;
|
||||||
|
|
||||||
|
})
|
||||||
|
|
||||||
|
$this.on('touchmove', function(event) {
|
||||||
|
|
||||||
|
if ($this.touchPosX === null
|
||||||
|
|| $this.touchPosY === null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
var diffX = $this.touchPosX - event.originalEvent.touches[0].pageX,
|
||||||
|
diffY = $this.touchPosY - event.originalEvent.touches[0].pageY,
|
||||||
|
th = $this.outerHeight(),
|
||||||
|
ts = ($this.get(0).scrollHeight - $this.scrollTop());
|
||||||
|
|
||||||
|
// Hide on swipe?
|
||||||
|
if (config.hideOnSwipe) {
|
||||||
|
|
||||||
|
var result = false,
|
||||||
|
boundary = 20,
|
||||||
|
delta = 50;
|
||||||
|
|
||||||
|
switch (config.side) {
|
||||||
|
|
||||||
|
case 'left':
|
||||||
|
result = (diffY < boundary && diffY > (-1 * boundary)) && (diffX > delta);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'right':
|
||||||
|
result = (diffY < boundary && diffY > (-1 * boundary)) && (diffX < (-1 * delta));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'top':
|
||||||
|
result = (diffX < boundary && diffX > (-1 * boundary)) && (diffY > delta);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'bottom':
|
||||||
|
result = (diffX < boundary && diffX > (-1 * boundary)) && (diffY < (-1 * delta));
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (result) {
|
||||||
|
|
||||||
|
$this.touchPosX = null;
|
||||||
|
$this.touchPosY = null;
|
||||||
|
$this._hide();
|
||||||
|
|
||||||
|
return false;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Prevent vertical scrolling past the top or bottom.
|
||||||
|
if (($this.scrollTop() < 0 && diffY < 0)
|
||||||
|
|| (ts > (th - 2) && ts < (th + 2) && diffY > 0)) {
|
||||||
|
|
||||||
|
event.preventDefault();
|
||||||
|
event.stopPropagation();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
// Event: Prevent certain events inside the panel from bubbling.
|
||||||
|
$this.on('click touchend touchstart touchmove', function(event) {
|
||||||
|
event.stopPropagation();
|
||||||
|
});
|
||||||
|
|
||||||
|
// Event: Hide panel if a child anchor tag pointing to its ID is clicked.
|
||||||
|
$this.on('click', 'a[href="#' + id + '"]', function(event) {
|
||||||
|
|
||||||
|
event.preventDefault();
|
||||||
|
event.stopPropagation();
|
||||||
|
|
||||||
|
config.target.removeClass(config.visibleClass);
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
// Body.
|
||||||
|
|
||||||
|
// Event: Hide panel on body click/tap.
|
||||||
|
$body.on('click touchend', function(event) {
|
||||||
|
$this._hide(event);
|
||||||
|
});
|
||||||
|
|
||||||
|
// Event: Toggle.
|
||||||
|
$body.on('click', 'a[href="#' + id + '"]', function(event) {
|
||||||
|
|
||||||
|
event.preventDefault();
|
||||||
|
event.stopPropagation();
|
||||||
|
|
||||||
|
config.target.toggleClass(config.visibleClass);
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
// Window.
|
||||||
|
|
||||||
|
// Event: Hide on ESC.
|
||||||
|
if (config.hideOnEscape)
|
||||||
|
$window.on('keydown', function(event) {
|
||||||
|
|
||||||
|
if (event.keyCode == 27)
|
||||||
|
$this._hide(event);
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Apply "placeholder" attribute polyfill to one or more forms.
|
||||||
|
* @return {jQuery} jQuery object.
|
||||||
|
*/
|
||||||
|
$.fn.placeholder = function() {
|
||||||
|
|
||||||
|
// Browser natively supports placeholders? Bail.
|
||||||
|
if (typeof (document.createElement('input')).placeholder != 'undefined')
|
||||||
|
return $(this);
|
||||||
|
|
||||||
|
// No elements?
|
||||||
|
if (this.length == 0)
|
||||||
|
return $this;
|
||||||
|
|
||||||
|
// Multiple elements?
|
||||||
|
if (this.length > 1) {
|
||||||
|
|
||||||
|
for (var i=0; i < this.length; i++)
|
||||||
|
$(this[i]).placeholder();
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Vars.
|
||||||
|
var $this = $(this);
|
||||||
|
|
||||||
|
// Text, TextArea.
|
||||||
|
$this.find('input[type=text],textarea')
|
||||||
|
.each(function() {
|
||||||
|
|
||||||
|
var i = $(this);
|
||||||
|
|
||||||
|
if (i.val() == ''
|
||||||
|
|| i.val() == i.attr('placeholder'))
|
||||||
|
i
|
||||||
|
.addClass('polyfill-placeholder')
|
||||||
|
.val(i.attr('placeholder'));
|
||||||
|
|
||||||
|
})
|
||||||
|
.on('blur', function() {
|
||||||
|
|
||||||
|
var i = $(this);
|
||||||
|
|
||||||
|
if (i.attr('name').match(/-polyfill-field$/))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (i.val() == '')
|
||||||
|
i
|
||||||
|
.addClass('polyfill-placeholder')
|
||||||
|
.val(i.attr('placeholder'));
|
||||||
|
|
||||||
|
})
|
||||||
|
.on('focus', function() {
|
||||||
|
|
||||||
|
var i = $(this);
|
||||||
|
|
||||||
|
if (i.attr('name').match(/-polyfill-field$/))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (i.val() == i.attr('placeholder'))
|
||||||
|
i
|
||||||
|
.removeClass('polyfill-placeholder')
|
||||||
|
.val('');
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
// Password.
|
||||||
|
$this.find('input[type=password]')
|
||||||
|
.each(function() {
|
||||||
|
|
||||||
|
var i = $(this);
|
||||||
|
var x = $(
|
||||||
|
$('<div>')
|
||||||
|
.append(i.clone())
|
||||||
|
.remove()
|
||||||
|
.html()
|
||||||
|
.replace(/type="password"/i, 'type="text"')
|
||||||
|
.replace(/type=password/i, 'type=text')
|
||||||
|
);
|
||||||
|
|
||||||
|
if (i.attr('id') != '')
|
||||||
|
x.attr('id', i.attr('id') + '-polyfill-field');
|
||||||
|
|
||||||
|
if (i.attr('name') != '')
|
||||||
|
x.attr('name', i.attr('name') + '-polyfill-field');
|
||||||
|
|
||||||
|
x.addClass('polyfill-placeholder')
|
||||||
|
.val(x.attr('placeholder')).insertAfter(i);
|
||||||
|
|
||||||
|
if (i.val() == '')
|
||||||
|
i.hide();
|
||||||
|
else
|
||||||
|
x.hide();
|
||||||
|
|
||||||
|
i
|
||||||
|
.on('blur', function(event) {
|
||||||
|
|
||||||
|
event.preventDefault();
|
||||||
|
|
||||||
|
var x = i.parent().find('input[name=' + i.attr('name') + '-polyfill-field]');
|
||||||
|
|
||||||
|
if (i.val() == '') {
|
||||||
|
|
||||||
|
i.hide();
|
||||||
|
x.show();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
x
|
||||||
|
.on('focus', function(event) {
|
||||||
|
|
||||||
|
event.preventDefault();
|
||||||
|
|
||||||
|
var i = x.parent().find('input[name=' + x.attr('name').replace('-polyfill-field', '') + ']');
|
||||||
|
|
||||||
|
x.hide();
|
||||||
|
|
||||||
|
i
|
||||||
|
.show()
|
||||||
|
.focus();
|
||||||
|
|
||||||
|
})
|
||||||
|
.on('keypress', function(event) {
|
||||||
|
|
||||||
|
event.preventDefault();
|
||||||
|
x.val('');
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
// Events.
|
||||||
|
$this
|
||||||
|
.on('submit', function() {
|
||||||
|
|
||||||
|
$this.find('input[type=text],input[type=password],textarea')
|
||||||
|
.each(function(event) {
|
||||||
|
|
||||||
|
var i = $(this);
|
||||||
|
|
||||||
|
if (i.attr('name').match(/-polyfill-field$/))
|
||||||
|
i.attr('name', '');
|
||||||
|
|
||||||
|
if (i.val() == i.attr('placeholder')) {
|
||||||
|
|
||||||
|
i.removeClass('polyfill-placeholder');
|
||||||
|
i.val('');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
})
|
||||||
|
.on('reset', function(event) {
|
||||||
|
|
||||||
|
event.preventDefault();
|
||||||
|
|
||||||
|
$this.find('select')
|
||||||
|
.val($('option:first').val());
|
||||||
|
|
||||||
|
$this.find('input,textarea')
|
||||||
|
.each(function() {
|
||||||
|
|
||||||
|
var i = $(this),
|
||||||
|
x;
|
||||||
|
|
||||||
|
i.removeClass('polyfill-placeholder');
|
||||||
|
|
||||||
|
switch (this.type) {
|
||||||
|
|
||||||
|
case 'submit':
|
||||||
|
case 'reset':
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'password':
|
||||||
|
i.val(i.attr('defaultValue'));
|
||||||
|
|
||||||
|
x = i.parent().find('input[name=' + i.attr('name') + '-polyfill-field]');
|
||||||
|
|
||||||
|
if (i.val() == '') {
|
||||||
|
i.hide();
|
||||||
|
x.show();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
i.show();
|
||||||
|
x.hide();
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'checkbox':
|
||||||
|
case 'radio':
|
||||||
|
i.attr('checked', i.attr('defaultValue'));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'text':
|
||||||
|
case 'textarea':
|
||||||
|
i.val(i.attr('defaultValue'));
|
||||||
|
|
||||||
|
if (i.val() == '') {
|
||||||
|
i.addClass('polyfill-placeholder');
|
||||||
|
i.val(i.attr('placeholder'));
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
i.val(i.attr('defaultValue'));
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Moves elements to/from the first positions of their respective parents.
|
||||||
|
* @param {jQuery} $elements Elements (or selector) to move.
|
||||||
|
* @param {bool} condition If true, moves elements to the top. Otherwise, moves elements back to their original locations.
|
||||||
|
*/
|
||||||
|
$.prioritize = function($elements, condition) {
|
||||||
|
|
||||||
|
var key = '__prioritize';
|
||||||
|
|
||||||
|
// Expand $elements if it's not already a jQuery object.
|
||||||
|
if (typeof $elements != 'jQuery')
|
||||||
|
$elements = $($elements);
|
||||||
|
|
||||||
|
// Step through elements.
|
||||||
|
$elements.each(function() {
|
||||||
|
|
||||||
|
var $e = $(this), $p,
|
||||||
|
$parent = $e.parent();
|
||||||
|
|
||||||
|
// No parent? Bail.
|
||||||
|
if ($parent.length == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Not moved? Move it.
|
||||||
|
if (!$e.data(key)) {
|
||||||
|
|
||||||
|
// Condition is false? Bail.
|
||||||
|
if (!condition)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Get placeholder (which will serve as our point of reference for when this element needs to move back).
|
||||||
|
$p = $e.prev();
|
||||||
|
|
||||||
|
// Couldn't find anything? Means this element's already at the top, so bail.
|
||||||
|
if ($p.length == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Move element to top of parent.
|
||||||
|
$e.prependTo($parent);
|
||||||
|
|
||||||
|
// Mark element as moved.
|
||||||
|
$e.data(key, $p);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moved already?
|
||||||
|
else {
|
||||||
|
|
||||||
|
// Condition is true? Bail.
|
||||||
|
if (condition)
|
||||||
|
return;
|
||||||
|
|
||||||
|
$p = $e.data(key);
|
||||||
|
|
||||||
|
// Move element back to its original location (using our placeholder).
|
||||||
|
$e.insertAfter($p);
|
||||||
|
|
||||||
|
// Unmark element as moved.
|
||||||
|
$e.removeData(key);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
})(jQuery);
|
BIN
service/static/logo.png
(Stored with Git LFS)
Normal file
BIN
service/static/logo.png
(Stored with Git LFS)
Normal file
Binary file not shown.
1672
service/static/main.css
Normal file
1672
service/static/main.css
Normal file
File diff suppressed because it is too large
Load Diff
BIN
service/static/overlay.png
(Stored with Git LFS)
Normal file
BIN
service/static/overlay.png
(Stored with Git LFS)
Normal file
Binary file not shown.
@ -1,8 +1,10 @@
|
|||||||
.content {
|
body {
|
||||||
align-items: center;
|
font-family: Verdana, Geneva, Tahoma, sans-serif;
|
||||||
justify-content: center;
|
|
||||||
margin: auto;
|
|
||||||
width: 75%;
|
|
||||||
text-align: center;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.container {
|
||||||
|
border: 1em;
|
||||||
|
width: 100%;
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;;
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user