2015-07-29 11:34:48 +00:00
|
|
|
$( document ).ready(function() {
|
|
|
|
|
2015-09-05 15:26:17 +00:00
|
|
|
// url
|
|
|
|
var url = window.location.pathname;
|
|
|
|
|
2015-09-24 20:32:41 +00:00
|
|
|
// Fix back button cache problem
|
|
|
|
window.onunload = function(){};
|
2015-09-24 14:47:33 +00:00
|
|
|
|
2015-09-14 06:39:53 +00:00
|
|
|
// Set theme
|
|
|
|
var theme = localStorage.getItem('theme');
|
2015-12-28 15:39:14 +00:00
|
|
|
if (theme === null) { theme = 'light'; }
|
2015-09-14 06:39:53 +00:00
|
|
|
|
|
|
|
set_theme(theme);
|
|
|
|
|
2015-09-24 14:47:33 +00:00
|
|
|
|
2015-08-05 16:28:59 +00:00
|
|
|
// Syntax highlighting Configuration
|
|
|
|
hljs.configure({
|
|
|
|
tabReplace: ' ', // 4 spaces
|
|
|
|
languages: [], // Languages used for auto-detection
|
|
|
|
});
|
|
|
|
|
|
|
|
$('code').each(function(i, block) {
|
|
|
|
hljs.highlightBlock(block);
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2015-07-29 11:34:48 +00:00
|
|
|
// Interesting DOM Elements
|
2015-09-24 14:47:33 +00:00
|
|
|
var html = $("html");
|
2015-07-29 11:34:48 +00:00
|
|
|
var sidebar = $("#sidebar");
|
|
|
|
var page_wrapper = $("#page-wrapper");
|
2015-12-27 22:17:59 +00:00
|
|
|
var content = $("#content");
|
|
|
|
|
|
|
|
|
|
|
|
// Add anchors for all content headers
|
|
|
|
content.find("h1, h2, h3, h4, h5").wrap(function(){
|
|
|
|
var wrapper = $("<a>");
|
|
|
|
wrapper.attr("name", $(this).text());
|
|
|
|
return wrapper;
|
|
|
|
});
|
2015-07-29 11:34:48 +00:00
|
|
|
|
2015-09-24 14:47:33 +00:00
|
|
|
|
|
|
|
// Toggle sidebar
|
2015-07-29 11:34:48 +00:00
|
|
|
$("#sidebar-toggle").click(function(event){
|
2015-09-24 14:47:33 +00:00
|
|
|
if ( html.hasClass("sidebar-hidden") ) {
|
|
|
|
html.removeClass("sidebar-hidden").addClass("sidebar-visible");
|
|
|
|
localStorage.setItem('sidebar', 'visible');
|
|
|
|
} else if ( html.hasClass("sidebar-visible") ) {
|
|
|
|
html.removeClass("sidebar-visible").addClass("sidebar-hidden");
|
|
|
|
localStorage.setItem('sidebar', 'hidden');
|
2015-07-29 11:34:48 +00:00
|
|
|
} else {
|
2015-09-24 14:47:33 +00:00
|
|
|
if(sidebar.position().left === 0){
|
|
|
|
html.addClass("sidebar-hidden");
|
|
|
|
localStorage.setItem('sidebar', 'hidden');
|
|
|
|
} else {
|
|
|
|
html.addClass("sidebar-visible");
|
|
|
|
localStorage.setItem('sidebar', 'visible');
|
|
|
|
}
|
2015-07-29 11:34:48 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2015-09-24 14:47:33 +00:00
|
|
|
|
2015-12-27 03:45:50 +00:00
|
|
|
// Scroll sidebar to current active section
|
|
|
|
var activeSection = sidebar.find(".active");
|
|
|
|
if(activeSection.length) {
|
|
|
|
sidebar.scrollTop(activeSection.offset().top);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-09-05 15:26:17 +00:00
|
|
|
// Print button
|
|
|
|
$("#print-button").click(function(){
|
|
|
|
var printWindow = window.open("print.html");
|
|
|
|
});
|
|
|
|
|
|
|
|
if( url.substring(url.lastIndexOf('/')+1) == "print.html" ) {
|
|
|
|
window.print();
|
|
|
|
}
|
|
|
|
|
2015-09-24 14:47:33 +00:00
|
|
|
|
2015-09-10 23:16:29 +00:00
|
|
|
// Theme button
|
|
|
|
$("#theme-toggle").click(function(){
|
|
|
|
if($('.theme-popup').length) {
|
|
|
|
$('.theme-popup').remove();
|
|
|
|
} else {
|
|
|
|
var popup = $('<div class="theme-popup"></div>')
|
|
|
|
.append($('<div class="theme" id="light">Light (default)<div>'))
|
2015-09-14 09:25:42 +00:00
|
|
|
.append($('<div class="theme" id="rust">Rust</div>'))
|
2015-09-14 06:39:53 +00:00
|
|
|
.append($('<div class="theme" id="coal">Coal</div>'))
|
|
|
|
.append($('<div class="theme" id="navy">Navy</div>'));
|
2015-09-10 23:16:29 +00:00
|
|
|
|
|
|
|
|
|
|
|
$(this).append(popup);
|
|
|
|
|
|
|
|
$('.theme').click(function(){
|
|
|
|
var theme = $(this).attr('id');
|
2015-09-14 06:39:53 +00:00
|
|
|
|
2015-12-28 15:39:14 +00:00
|
|
|
set_theme(theme);
|
2015-09-10 23:16:29 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2015-09-14 06:39:53 +00:00
|
|
|
function set_theme(theme) {
|
|
|
|
if (theme == 'coal' || theme == 'navy') {
|
|
|
|
$("[href='tomorrow-night.css']").prop('disabled', false);
|
|
|
|
$("[href='highlight.css']").prop('disabled', true);
|
|
|
|
} else {
|
|
|
|
$("[href='tomorrow-night.css']").prop('disabled', true);
|
|
|
|
$("[href='highlight.css']").prop('disabled', false);
|
|
|
|
}
|
|
|
|
|
|
|
|
localStorage.setItem('theme', theme);
|
|
|
|
|
|
|
|
$('body').removeClass().addClass(theme);
|
|
|
|
}
|
2015-12-28 22:52:05 +00:00
|
|
|
|
|
|
|
|
|
|
|
// Hide Rust code lines prepended with a specific character
|
|
|
|
var hiding_character = "#";
|
|
|
|
|
|
|
|
$("code.language-rust").each(function(i, block){
|
|
|
|
var lines = $(this).html().split("\n");
|
2015-12-29 11:26:32 +00:00
|
|
|
var first_non_hidden_line = false;
|
2015-12-28 22:52:05 +00:00
|
|
|
|
|
|
|
for(var n = 0; n < lines.length; n++){
|
|
|
|
if($.trim(lines[n])[0] == hiding_character){
|
2015-12-29 11:26:32 +00:00
|
|
|
lines[n] = "<span class=\"hidden\">" + lines[n] + "</span>";
|
|
|
|
}
|
|
|
|
else if(first_non_hidden_line) {
|
|
|
|
lines[n] = "\n" + lines[n];
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
first_non_hidden_line = true;
|
2015-12-28 22:52:05 +00:00
|
|
|
}
|
|
|
|
}
|
2015-12-29 11:26:32 +00:00
|
|
|
$(this).html(lines.join(""));
|
2015-12-28 22:52:05 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
|
2015-07-29 11:34:48 +00:00
|
|
|
});
|